# Port\_AUTOSAR

AUTHOR: Islam Ehab Ezzat Version 1.1.2 Thu Dec 31 2020

# **Data Structure Index**

### **Data Structures**

| Here are the data structures with brief descriptions:                                  |      |
|----------------------------------------------------------------------------------------|------|
| Dio_ChannelGroupType                                                                   | 4    |
| Dio_ConfigChannel                                                                      | 5    |
| Dio_ConfigType                                                                         | 6    |
| Port_ConfigChannel (Used to set the configurations of a Specific pin in Port Module )  | 7    |
| Port_ConfigType (This structure holds an array of structures that holds the configurat | ions |
| of the pins )                                                                          | 9    |

# **File Index**

### **File List**

Here is a list of all files with brief descriptions:

| App.c                      | 11 |
|----------------------------|----|
| App.h                      | 13 |
| Button.c                   | 15 |
| Button.h                   | 16 |
| Common_Macros.h            | 18 |
| Compiler.h                 | 19 |
| Det.c                      | 21 |
| Det.h                      | 22 |
| Dio.c                      | 24 |
| Dio.h                      | 26 |
| Dio_Cfg.h                  | 31 |
| Dio_PBcfg.c                | 33 |
| Dio_Regs.h                 | 35 |
| Gpt.c                      | 36 |
| Gpt.h                      | 38 |
| Led.c                      | 39 |
| Led.h                      | 41 |
| main.c                     | 43 |
| Os.c                       | 44 |
| Os.h                       | 46 |
| Platform_Types.h           | 48 |
| Port.c                     | 51 |
| Port.h                     | 54 |
| Port_Cfg.h                 | 70 |
| Port_PBcfg.c               | 72 |
| Port_Reg.h                 | 74 |
| Std_Types.h                | 78 |
| tm4c123gh6pm_registers.h   | 80 |
| tm4c123gh6pm_startup_ccs.c | 90 |

# **Data Structure Documentation**

# Dio\_ChannelGroupType Struct Reference

#include <Dio.h>

#### **Data Fields**

- uint8 mask
- uint8 offset
- Dio\_PortType PortIndex

#### **Field Documentation**

uint8 Dio\_ChannelGroupType::mask

uint8 Dio\_ChannelGroupType::offset

Dio\_PortType Dio\_ChannelGroupType::PortIndex

The documentation for this struct was generated from the following file:

• Dio.h

# **Dio\_ConfigChannel Struct Reference**

#include <Dio.h>

#### **Data Fields**

- Dio\_PortType Port\_Num
- Dio\_ChannelType Ch\_Num

#### **Field Documentation**

Dio\_ChannelType Dio\_ConfigChannel::Ch\_Num

Dio\_PortType Dio\_ConfigChannel::Port\_Num

The documentation for this struct was generated from the following file:

• Dio.h

# Dio\_ConfigType Struct Reference

#include <Dio.h>

Collaboration diagram for Dio\_ConfigType:



#### **Data Fields**

• Dio\_ConfigChannel Channels [DIO\_CONFIGURED\_CHANNLES]

#### **Field Documentation**

Dio\_ConfigChannel Dio\_ConfigType::Channels[DIO\_CONFIGURED\_CHANNLES]

The documentation for this struct was generated from the following file:

• Dio.h

### Port\_ConfigChannel Struct Reference

Used to set the configurations of a Specific pin in Port Module. #include <Port.h>

#### **Data Fields**

- Port\_PinType pinNum
- Port\_PortNumEnum portNum
- Port\_PinDirectionType direction
- Port PinModeType mode
- Port InternalResistor resistor
- uint8 pinDirection\_Changeable
- uint8 pinMode\_Changeable
- uint8 initialValue
- uint8 slewRate

#### **Detailed Description**

Used to set the configurations of a Specific pin in Port Module.

#### **Field Documentation**

#### Port\_ConfigChannel::direction

member 'portNum' used to decide which port are used with the required pin You can find its vale **Port\_PortNumEnum** 

member 'direction' used to decide if the pin is input or output You can find its value **Port\_PinDirectionType** 

#### Port\_ConfigChannel::initialValue

member 'pinMode\_Changable' used to decide if the pin mode can be changeable during run time or not You can find its value PIN\_MODE\_CHANGEABILITY

member 'initialValue' used to set an initial value for output pins You can find its value INITIAL\_VALUE

#### Port ConfigChannel::mode

member 'direction' used to decide if the pin is input or output You can find its value **Port\_PinDirectionType** 

member 'mode' used to decide which mode is used to decide which mode is used (GPIO or any alternative function) You can find its value **Port\_PinModeEnum** Note: if you want to use Analog function put **ANALOG\_MODE\_SELECTED** 

#### uint8 Port ConfigChannel::pinDirection Changeable

member 'resistor' used to decide if the internal resistor is enabled or not and its mode if enabled You can find its value **Port\_InternalResistor** 

#### uint8 Port\_ConfigChannel::pinMode\_Changeable

member 'pinDirection\_Changable' used to decide if the pin direction can be Changeable in run time or not You can find its value PIN\_DIRECTION\_CHANGEABILITY

#### Port\_ConfigChannel::pinNum

member 'pinNum' used to hold Pin & port number You can find its value **Port\_PinNumEnum** 

#### Port\_ConfigChannel::portNum

member 'pinNum' used to hold Pin & port number You can find its value **Port\_PinNumEnum** 

member 'portNum' used to decide which port are used with the required pin You can find its vale **Port PortNumEnum** 

#### Port\_ConfigChannel::resistor

member 'mode' used to decide which mode is used (GPIO or any alternative function) You can find its value **Port\_PinModeEnum** Note: if you want to use Analog function put **ANALOG\_MODE\_SELECTED** 

member 'resistor' used to decide if internal resistor is used or not and its mode if used (Pull-up or Pull-Down) You can find its value **Port\_InternalResistor** 

#### Port\_ConfigChannel::slewRate

member 'initialValue' used to set an initial value for output pins You can find its value INITIAL\_VALUE

member 'slewRate' used to decide if Slew rate is enabled/disabled for the pin You can find its value SLEW\_RATE

#### The documentation for this struct was generated from the following file:

• Port.h

### Port\_ConfigType Struct Reference

This structure holds an array of structures that holds the configurations of the pins. #include < Port.h>

Collaboration diagram for Port\_ConfigType:



#### **Data Fields**

• Port\_ConfigChannel portChannels [PORT\_CONFIGURED\_CHANNLES]

#### **Detailed Description**

This structure holds an array of structures that holds the configurations of the pins.

#### Note

Unused pins shall configured with the initial value which got from TM4C123GH6PM data sheet, GPIO chapter so that, PORT\_CONFIGURED\_CHANNELS shall equal 39 in TM4C123GH6PM

#### **Field Documentation**

#### Port\_ConfigType::portChannels

member 'portChannels' used as an array to hold the configurations of the pins

The documentation for this struct was generated from the following file:

• Port.h

### Std\_VersionInfoType Struct Reference

#include <Std\_Types.h>

#### **Data Fields**

- uint16 vendorID
- uint16 moduleID
- uint8 sw\_major\_version
- uint8 sw\_minor\_version
- uint8 sw\_patch\_version

#### **Field Documentation**

uint16 Std\_VersionInfoType::moduleID

uint8 Std\_VersionInfoType::sw\_major\_version

uint8 Std\_VersionInfoType::sw\_minor\_version

uint8 Std\_VersionInfoType::sw\_patch\_version

uint16 Std\_VersionInfoType::vendorID

The documentation for this struct was generated from the following file:

Std\_Types.h

# **File Documentation**

### **App.c File Reference**

```
#include "App.h"
#include "Button.h"
#include "Led.h"
#include "Port.h"
#include "Dio.h"
```

Include dependency graph for App.c:



#### **Functions**

- void **Init\_Task** (void)
- void Button\_Task (void)
- void Led\_Task (void)
- void App\_Task (void)

#### **Function Documentation**

#### void App\_Task (void )

Here is the call graph for this function:



#### void Button\_Task (void )

Here is the call graph for this function:



#### void Init\_Task (void )



### void Led\_Task (void )



### **App.h File Reference**

#include "Std\_Types.h"
Include dependency graph for App.h:



This graph shows which files directly or indirectly include this file:



#### **Functions**

- void Init\_Task (void)
- void Button\_Task (void)
- void Led\_Task (void)
- void **App\_Task** (void)

#### **Function Documentation**

#### void App\_Task (void )

Here is the call graph for this function:



#### void Button\_Task (void )

Here is the call graph for this function:



#### void Init\_Task (void )



### void Led\_Task (void )



#### **Button.c File Reference**

#include "Dio.h"
#include "Port.h"
#include "Button.h"

Include dependency graph for Button.c:



#### **Functions**

- uint8 BUTTON\_getState (void)
- void **BUTTON\_refreshState** (void)

#### **Function Documentation**

#### uint8 BUTTON\_getState (void )

Here is the caller graph for this function:



#### void BUTTON\_refreshState (void )



#### **Button.h File Reference**

#include "Std\_Types.h"
Include dependency graph for Button.h:



This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **BUTTON\_PRESSED STD\_LOW**
- #define BUTTON\_RELEASED STD\_HIGH

#### **Functions**

- uint8 BUTTON\_getState (void)
- void **BUTTON\_refreshState** (void)

#### **Macro Definition Documentation**

#define BUTTON\_PRESSED STD\_LOW

#define BUTTON\_RELEASED STD\_HIGH

#### **Function Documentation**

#### uint8 BUTTON\_getState (void )

Here is the caller graph for this function:



#### void BUTTON\_refreshState (void )



### Common\_Macros.h File Reference

This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **SET\_BIT**(REG, BIT) (REG|=(1<<BIT))
- #define **CLEAR\_BIT**(REG, BIT) (REG&=(~(1<<BIT)))
- #define **TOGGLE\_BIT**(REG, BIT) (REG^=(1<<BIT))
- #define ROR(REG, num) ( REG = (REG>>num) | (REG << ((sizeof(REG) \* 8)-num)) )</li>
- #define ROL(REG, num) (REG = (REG << num) | (REG >> ((sizeof(REG) \* 8)-num)))
- #define **BIT\_IS\_SET**(REG, BIT) ( REG & (1<<BIT) )
- #define **BIT\_IS\_CLEAR**(REG, BIT) (!(REG & (1<<BIT)))

#### **Macro Definition Documentation**

```
#define BIT_IS_CLEAR( REG, BIT) (!(REG & (1<<BIT)))
#define BIT_IS_SET( REG, BIT) ( REG & (1<<BIT))
#define CLEAR_BIT( REG, BIT) (REG&=(~(1<<BIT)))
#define ROL( REG, num) ( REG = (REG<<num) | (REG >> ((sizeof(REG) * 8)-num)) )
#define ROR( REG, num) ( REG = (REG>>num) | (REG << ((sizeof(REG) * 8)-num)) )
#define SET_BIT( REG, BIT) (REG|=(1<<BIT))
#define TOGGLE_BIT( REG, BIT) (REG^=(1<<BIT))</pre>
```

### Compiler.h File Reference

This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **COMPILER\_VENDOR\_ID** (1000U)
- #define **COMPILER\_SW\_MAJOR\_VERSION** (1U)
- #define COMPILER\_SW\_MINOR\_VERSION (0U)
- #define COMPILER\_SW\_PATCH\_VERSION (0U)
- #define **COMPILER\_AR\_RELEASE\_MAJOR\_VERSION** (4U)
- #define COMPILER\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define **COMPILER\_AR\_RELEASE\_PATCH\_VERSION** (3U)
- #define AUTOMATIC
- #define **TYPEDEF**
- #define **NULL\_PTR** ((void \*)0)
- #define **INLINE** inline
- #define LOCAL\_INLINE static inline
- #define **STATIC** static

#### **Macro Definition Documentation**

#define AUTOMATIC

#define COMPILER\_AR\_RELEASE\_MAJOR\_VERSION (4U)

#define COMPILER\_AR\_RELEASE\_MINOR\_VERSION (0U)

#define COMPILER\_AR\_RELEASE\_PATCH\_VERSION (3U)

#define COMPILER\_SW\_MAJOR\_VERSION (1U)

#define COMPILER\_SW\_MINOR\_VERSION (0U)

#define COMPILER\_SW\_PATCH\_VERSION (0U)

#define COMPILER\_VENDOR\_ID (1000U)

#define INLINE inline

#define LOCAL\_INLINE static inline

#define NULL\_PTR ((void \*)0)

#define STATIC static

#define TYPEDEF

#### **Det.c File Reference**

#include "Det.h"

Include dependency graph for Det.c:



#### **Functions**

• Std\_ReturnType Det\_ReportError (uint16 ModuleId, uint8 InstanceId, uint8 ApiId, uint8 ErrorId)

#### **Function Documentation**

# Std\_ReturnType Det\_ReportError (uint16 *Moduleld*, uint8 *Instanceld*, uint8 *Apild*, uint8 *Errorld*)



#### **Det.h File Reference**

#include "Std\_Types.h"
Include dependency graph for Det.h:



This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **DET\_VENDOR\_ID** (1000U)
- #define **DET\_MODULE\_ID** (15U)
- #define **DET\_INSTANCE\_ID** (0U)
- #define **DET\_SW\_MAJOR\_VERSION** (1U)
- #define **DET\_SW\_MINOR\_VERSION** (0U)
- #define **DET\_SW\_PATCH\_VERSION** (0U)
- #define **DET\_AR\_MAJOR\_VERSION** (4U)
- #define **DET\_AR\_MINOR\_VERSION** (0U)
- #define **DET\_AR\_PATCH\_VERSION** (3U)

#### **Functions**

• Std\_ReturnType Det\_ReportError (uint16 ModuleId, uint8 InstanceId, uint8 ApiId, uint8 ErrorId)

#### **Macro Definition Documentation**

#define DET\_AR\_MAJOR\_VERSION (4U)

#define DET\_AR\_MINOR\_VERSION (0U)

#define DET\_AR\_PATCH\_VERSION (3U)

#define DET\_INSTANCE\_ID (0U)

#define DET\_MODULE\_ID (15U)

#define DET\_SW\_MAJOR\_VERSION (1U)

#define DET\_SW\_MINOR\_VERSION (0U)

#define DET\_SW\_PATCH\_VERSION (0U)

#define DET\_VENDOR\_ID (1000U)

#### **Function Documentation**

# Std\_ReturnType Det\_ReportError (uint16 *Moduleld*, uint8 *Instanceld*, uint8 *Apild*, uint8 *Errorld*)



#### Dio.c File Reference

#include "Dio.h"
#include "Dio\_Regs.h"
#include "Det.h"

Include dependency graph for Dio.c:



#### **Functions**

- void **Dio\_Init** (const **Dio\_ConfigType** \*ConfigPtr)
- void Dio\_WriteChannel (Dio\_ChannelType ChannelId, Dio\_LevelType Level)
- **Dio\_LevelType Dio\_ReadChannel (Dio\_ChannelType** ChannelId)
- Dio\_LevelType Dio\_FlipChannel (Dio\_ChannelType ChannelId)

#### **Variables**

- const STATIC Dio\_ConfigChannel \* Dio\_PortChannels = NULL\_PTR
- STATIC uint8 Dio\_Status = DIO\_NOT\_INITIALIZED

#### **Function Documentation**

#### Dio\_LevelType Dio\_FlipChannel (Dio\_ChannelType ChannelId)

Here is the call graph for this function:



Here is the caller graph for this function:



#### void Dio\_Init (const Dio\_ConfigType \* ConfigPtr)

Here is the call graph for this function:





#### Dio\_LevelType Dio\_ReadChannel (Dio\_ChannelType ChannelId)

Here is the call graph for this function:



Here is the caller graph for this function:



#### void Dio\_WriteChannel (Dio\_ChannelType ChannelId, Dio\_LevelType Level)

Here is the call graph for this function:



LED\_setOn

#### **Variable Documentation**

const STATIC Dio\_ConfigChannel\* Dio\_PortChannels = NULL\_PTR

STATIC uint8 Dio\_Status = DIO\_NOT\_INITIALIZED

#### Dio.h File Reference

#include "Std\_Types.h"
#include "Dio\_Cfg.h"
#include "Common\_Macros.h"
Include dependency graph for Dio.h:



This graph shows which files directly or indirectly include this file:



#### **Data Structures**

- struct Dio ChannelGroupType
- struct Dio\_ConfigChannel
- struct **Dio\_ConfigType**

#### **Macros**

- #define **DIO\_VENDOR\_ID** (1000U)
- #define **DIO\_MODULE\_ID** (120U)
- #define **DIO\_INSTANCE\_ID** (0U)
- #define **DIO\_SW\_MAJOR\_VERSION** (1U)
- #define **DIO\_SW\_MINOR\_VERSION** (0U)
- #define **DIO\_SW\_PATCH\_VERSION** (0U)
- #define DIO\_AR\_RELEASE\_MAJOR\_VERSION (4U)
- #define **DIO\_AR\_RELEASE\_MINOR\_VERSION** (0U)
- #define **DIO\_AR\_RELEASE\_PATCH\_VERSION** (3U)
- #define **DIO\_INITIALIZED** (1U)
- #define **DIO\_NOT\_INITIALIZED** (0U)
- #define **DIO\_READ\_CHANNEL\_SID** (uint8)0x00
- #define DIO\_WRITE\_CHANNEL\_SID (uint8)0x01
- #define DIO READ PORT SID (uint8)0x02
- #define **DIO\_WRITE\_PORT\_SID** (**uint8**)0x03
- #define DIO\_READ\_CHANNEL\_GROUP\_SID (uint8)0x04
- #define **DIO WRITE CHANNEL GROUP SID** (**uint8**)0x05
- #define **DIO\_GET\_VERSION\_INFO\_SID** (uint8)0x12
- #define **DIO\_INIT\_SID** (**uint8**)0x10
- #define **DIO\_FLIP\_CHANNEL\_SID** (**uint8**)0x11

- #define DIO\_E\_PARAM\_INVALID\_CHANNEL\_ID (uint8)0x0A
- #define **DIO\_E\_PARAM\_CONFIG** (**uint8**)0x10
- #define **DIO\_E\_PARAM\_INVALID\_PORT\_ID** (**uint8**)0x14
- #define **DIO\_E\_PARAM\_INVALID\_GROUP** (**uint8**)0x1F
- #define **DIO\_E\_PARAM\_POINTER** (uint8)0x20
- #define **DIO E UNINIT** (**uint8**)0xF0

#### **Typedefs**

- typedef uint8 Dio\_ChannelType
- typedef uint8 Dio\_PortType
- typedef uint8 Dio\_LevelType
- typedef uint8 Dio\_PortLevelType
- typedef struct Dio\_ConfigType Dio\_ConfigType

#### **Functions**

- Dio\_PortLevelType Dio\_ReadPort (Dio\_PortType PortId)
- void **Dio\_WritePort** (**Dio\_PortType** PortId, **Dio\_PortLevelType** Level)
- **Dio LevelType Dio ReadChannel (Dio ChannelType** ChannelId)
- void Dio\_WriteChannel (Dio\_ChannelType ChannelId, Dio\_LevelType Level)
- void **Dio\_Init** (const **Dio\_ConfigType** \*ConfigPtr)
- Dio\_LevelType Dio\_FlipChannel (Dio\_ChannelType ChannelId)

#### **Variables**

• const Dio\_ConfigType Dio\_Configuration

#### **Macro Definition Documentation**

#define DIO\_AR\_RELEASE\_MAJOR\_VERSION (4U)

#define DIO\_AR\_RELEASE\_MINOR\_VERSION (0U)

#define DIO\_AR\_RELEASE\_PATCH\_VERSION (3U)

#define DIO\_E\_PARAM\_CONFIG (uint8)0x10

#define DIO\_E\_PARAM\_INVALID\_CHANNEL\_ID (uint8)0x0A

#define DIO\_E\_PARAM\_INVALID\_GROUP (uint8)0x1F

#define DIO\_E\_PARAM\_INVALID\_PORT\_ID (uint8)0x14

#define DIO\_E\_PARAM\_POINTER (uint8)0x20

#define DIO\_E\_UNINIT (uint8)0xF0

#define DIO\_FLIP\_CHANNEL\_SID (uint8)0x11

#define DIO\_GET\_VERSION\_INFO\_SID (uint8)0x12

#define DIO\_INIT\_SID (uint8)0x10

#define DIO\_INITIALIZED (1U)

#define DIO\_INSTANCE\_ID (0U)

#define DIO MODULE ID (120U)

#define DIO\_NOT\_INITIALIZED (0U)

#define DIO\_READ\_CHANNEL\_GROUP\_SID (uint8)0x04

#define DIO\_READ\_CHANNEL\_SID (uint8)0x00

#define DIO\_READ\_PORT\_SID (uint8)0x02

#define DIO\_SW\_MAJOR\_VERSION (1U)

#define DIO\_SW\_MINOR\_VERSION (0U)

#define DIO\_SW\_PATCH\_VERSION (0U)

#define DIO\_VENDOR\_ID (1000U)

#define DIO\_WRITE\_CHANNEL\_GROUP\_SID (uint8)0x05

#define DIO\_WRITE\_CHANNEL\_SID (uint8)0x01

#### **Typedef Documentation**

typedef uint8 Dio\_ChannelType

typedef struct Dio\_ConfigType Dio\_ConfigType

typedef uint8 Dio\_LevelType

typedef uint8 Dio\_PortLevelType

typedef uint8 Dio\_PortType

#### **Function Documentation**

#### Dio\_LevelType Dio\_FlipChannel (Dio\_ChannelType ChannelId)

Here is the call graph for this function:



Here is the caller graph for this function:



#### void Dio\_Init (const Dio\_ConfigType \* ConfigPtr)

Here is the call graph for this function:



Init\_Task

Dio\_Init

main



Os\_start

Here is the call graph for this function:



Here is the caller graph for this function:



#### Dio\_PortLevelType Dio\_ReadPort (Dio\_PortType PortId)

#### void Dio\_WriteChannel (Dio\_ChannelType ChannelId, Dio\_LevelType Level)

Here is the call graph for this function:





#### **Variable Documentation**

const Dio\_ConfigType Dio\_Configuration

### Dio\_Cfg.h File Reference

This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **DIO\_CFG\_SW\_MAJOR\_VERSION** (1U)
- #define **DIO\_CFG\_SW\_MINOR\_VERSION** (0U)
- #define **DIO\_CFG\_SW\_PATCH\_VERSION** (0U)
- #define DIO\_CFG\_AR\_RELEASE\_MAJOR\_VERSION (4U)
- #define DIO\_CFG\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define DIO\_CFG\_AR\_RELEASE\_PATCH\_VERSION (3U)
- #define DIO\_DEV\_ERROR\_DETECT (STD\_ON)
- #define DIO\_VERSION\_INFO\_API (STD\_OFF)
- #define DIO\_FLIP\_CHANNEL\_API (STD\_ON)
- #define **DIO\_CONFIGURED\_CHANNLES** (2U)
- #define DioConf\_LED1\_CHANNEL\_ID\_INDEX (uint8)0x00
- #define DioConf\_SW1\_CHANNEL\_ID\_INDEX (uint8)0x01
- #define DioConf\_LED1\_PORT\_NUM (Dio\_PortType)5 /\* PORTF \*/
- #define DioConf\_SW1\_PORT\_NUM (Dio\_PortType)5 /\* PORTF \*/
- #define DioConf\_LED1\_CHANNEL\_NUM (Dio\_ChannelType)2 /\* Pin 1 in PORTF \*/
- #define DioConf SW1 CHANNEL NUM (Dio ChannelType)4 /\* Pin 4 in PORTF \*/

#### **Macro Definition Documentation**

```
#define DIO CFG AR RELEASE MAJOR VERSION (4U)
#define DIO_CFG_AR_RELEASE_MINOR_VERSION (0U)
#define DIO_CFG_AR_RELEASE_PATCH_VERSION (3U)
#define DIO_CFG_SW_MAJOR_VERSION (1U)
#define DIO_CFG_SW_MINOR_VERSION (0U)
#define DIO_CFG_SW_PATCH_VERSION (0U)
#define DIO_CONFIGURED_CHANNLES (2U)
#define DIO_DEV_ERROR_DETECT (STD_ON)
#define DIO_FLIP_CHANNEL_API (STD_ON)
#define DIO_VERSION_INFO_API (STD_OFF)
#define DioConf_LED1_CHANNEL_ID_INDEX (uint8)0x00
#define DioConf_LED1_CHANNEL_NUM (Dio_ChannelType)2 /* Pin 1 in PORTF */
#define DioConf_LED1_PORT_NUM (Dio_PortType)5 /* PORTF */
#define DioConf_SW1_CHANNEL_ID_INDEX (uint8)0x01
#define DioConf_SW1_CHANNEL_NUM (Dio_ChannelType)4 /* Pin 4 in PORTF */
#define DioConf_SW1_PORT_NUM (Dio_PortType)5 /* PORTF */
```

### Dio\_PBcfg.c File Reference

#include "Dio.h"

Include dependency graph for Dio\_PBcfg.c:



#### **Macros**

- #define DIO\_PBCFG\_SW\_MAJOR\_VERSION (1U)
- #define DIO\_PBCFG\_SW\_MINOR\_VERSION (0U)
- #define **DIO\_PBCFG\_SW\_PATCH\_VERSION** (0U)
- #define **DIO PBCFG AR RELEASE MAJOR VERSION** (4U)
- #define DIO\_PBCFG\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define DIO\_PBCFG\_AR\_RELEASE\_PATCH\_VERSION (3U)

#### **Variables**

• const Dio\_ConfigType Dio\_Configuration

#### **Macro Definition Documentation**

#define DIO\_PBCFG\_AR\_RELEASE\_MAJOR\_VERSION (4U)

#define DIO\_PBCFG\_AR\_RELEASE\_MINOR\_VERSION (0U)

#define DIO\_PBCFG\_AR\_RELEASE\_PATCH\_VERSION (3U)

#define DIO\_PBCFG\_SW\_MAJOR\_VERSION (1U)

#define DIO\_PBCFG\_SW\_MINOR\_VERSION (0U)

#define DIO\_PBCFG\_SW\_PATCH\_VERSION (0U)

#### **Variable Documentation**

#### const Dio\_ConfigType Dio\_Configuration

Initial value:= {

DioConf\_LED1\_PORT\_NUM, DioConf\_LED1\_CHANNEL\_NUM,
DioConf\_SW1\_PORT\_NUM, DioConf\_SW1\_CHANNEL\_NUM

### Dio\_Regs.h File Reference

#include "Std\_Types.h"
Include dependency graph for Dio\_Regs.h:



This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **GPIO\_PORTA\_DATA\_REG** (\*((volatile **uint32** \*)0x400043FC))
- #define **GPIO\_PORTB\_DATA\_REG** (\*((volatile **uint32** \*)0x400053FC))
- #define **GPIO\_PORTC\_DATA\_REG** (\*((volatile **uint32** \*)0x400063FC))
- #define **GPIO\_PORTD\_DATA\_REG** (\*((volatile **uint32** \*)0x400073FC))
- #define **GPIO\_PORTE\_DATA\_REG** (\*((volatile **uint32** \*)0x400243FC))
- #define **GPIO\_PORTF\_DATA\_REG** (\*((volatile **uint32** \*)0x400253FC))

#### **Macro Definition Documentation**

#define GPIO\_PORTA\_DATA\_REG (\*((volatile uint32 \*)0x400043FC))
#define GPIO\_PORTB\_DATA\_REG (\*((volatile uint32 \*)0x400053FC))
#define GPIO\_PORTC\_DATA\_REG (\*((volatile uint32 \*)0x400063FC))
#define GPIO\_PORTD\_DATA\_REG (\*((volatile uint32 \*)0x400073FC))
#define GPIO\_PORTE\_DATA\_REG (\*((volatile uint32 \*)0x400243FC))
#define GPIO\_PORTF\_DATA\_REG (\*((volatile uint32 \*)0x400253FC))

### **Gpt.c File Reference**

#include "Gpt.h"

#include "tm4c123gh6pm\_registers.h"

Include dependency graph for Gpt.c:



#### **Macros**

- #define **SYSTICK\_PRIORITY\_MASK** 0x1FFFFFFF
- #define **SYSTICK\_INTERRUPT\_PRIORITY** 3
- #define **SYSTICK\_PRIORITY\_BITS\_POS** 29

#### **Functions**

- void SysTick\_Handler (void)
- void **SysTick\_Start** (**uint16** Tick\_Time)
- void **SysTick\_Stop** (void)
- void **SysTick\_SetCallBack** (void(\*Ptr2Func)(void))

#### **Macro Definition Documentation**

#define SYSTICK\_INTERRUPT\_PRIORITY 3

#define SYSTICK\_PRIORITY\_BITS\_POS 29

#define SYSTICK\_PRIORITY\_MASK 0x1FFFFFF

#### **Function Documentation**

void SysTick\_Handler (void )

#### void SysTick\_SetCallBack (void(\*)(void) Ptr2Func)



# 

Here is the caller graph for this function:



void SysTick\_Stop (void )

# **Gpt.h File Reference**

#include "Std\_Types.h"
Include dependency graph for Gpt.h:



This graph shows which files directly or indirectly include this file:



# **Functions**

- void **SysTick\_Start** (**uint16** Tick\_Time)
- void **SysTick\_Stop** (void)
- void **SysTick\_SetCallBack** (void(\*Ptr2Func)(void))

## **Function Documentation**

# void SysTick\_SetCallBack (void(\*)(void) Ptr2Func)

Here is the caller graph for this function:



## void SysTick\_Start (uint16 Tick\_Time)

Here is the caller graph for this function:



# void SysTick\_Stop (void )

# Led.c File Reference

```
#include "Port.h"
#include "Dio.h"
#include "Led.h"
```

Include dependency graph for Led.c:



## **Functions**

- void LED\_setOn (void)
- void **LED** setOff (void)
- void LED\_refreshOutput (void)
- void **LED\_toggle** (void)

## **Function Documentation**

## void LED\_refreshOutput (void )

Here is the call graph for this function:



Here is the caller graph for this function:



#### void LED\_setOff (void )

Here is the call graph for this function:



## void LED\_setOn (void )



# void LED\_toggle (void )

Here is the call graph for this function:





# Led.h File Reference

#include "Std\_Types.h"
Include dependency graph for Led.h:



This graph shows which files directly or indirectly include this file:



## **Macros**

- #define **LED\_ON STD\_HIGH**
- #define LED\_OFF STD\_LOW
- #define LED\_PORT DioConf\_LED1\_PORT\_NUM
- #define LED\_PIN\_NUM DioConf\_LED1\_CHANNEL\_NUM

### **Functions**

- void **LED** setOn (void)
- void **LED\_setOff** (void)
- void **LED\_toggle** (void)
- void LED\_refreshOutput (void)

### **Macro Definition Documentation**

#define LED\_OFF STD\_LOW

#define LED\_ON STD\_HIGH

#define LED\_PIN\_NUM DioConf\_LED1\_CHANNEL\_NUM

#define LED\_PORT DioConf\_LED1\_PORT\_NUM

## **Function Documentation**

## void LED\_refreshOutput (void )

Here is the call graph for this function:



Here is the caller graph for this function:



# void LED\_setOff (void )

Here is the call graph for this function:



## void LED\_setOn (void )

Here is the call graph for this function:



## void LED\_toggle (void )

Here is the call graph for this function:





# main.c File Reference

#include "Os.h"

Include dependency graph for main.c:



# **Functions**

• int main (void)

# **Function Documentation**

## int main (void)



# Os.c File Reference

```
#include "Os.h"
#include "App.h"
#include "Button.h"
#include "Led.h"
#include "Gpt.h"
```

Include dependency graph for Os.c:



### **Macros**

- #define Enable\_Interrupts() \_\_asm(" CPSIE I")
- #define **Disable\_Interrupts**() \_\_asm(" CPSID I")

### **Functions**

- void Os\_start (void)
- void Os NewTimerTick (void)
- void **Os\_Scheduler** (void)

## **Macro Definition Documentation**

```
#define Disable_Interrupts() __asm(" CPSID I")
#define Enable_Interrupts() __asm(" CPSIE I")
```

## **Function Documentation**

### void Os\_NewTimerTick (void )

Here is the caller graph for this function:



## void Os\_Scheduler (void )



# void Os\_start (void )

Here is the call graph for this function:





# Os.h File Reference

#include "Std\_Types.h"
Include dependency graph for Os.h:



This graph shows which files directly or indirectly include this file:



## **Macros**

• #define **OS\_BASE\_TIME** 20

## **Functions**

- void **Os\_start** (void)
- void Os\_Scheduler (void)
- void **Os\_NewTimerTick** (void)

# **Macro Definition Documentation**

#define OS\_BASE\_TIME 20

## **Function Documentation**

## void Os\_NewTimerTick (void )

Here is the caller graph for this function:



# void Os\_Scheduler (void )



# void Os\_start (void )



# Platform\_Types.h File Reference

This graph shows which files directly or indirectly include this file:



## **Macros**

- #define **PLATFORM VENDOR ID** (1000U)
- #define **PLATFORM\_SW\_MAJOR\_VERSION** (1U)
- #define **PLATFORM\_SW\_MINOR\_VERSION** (0U)
- #define **PLATFORM\_SW\_PATCH\_VERSION** (0U)
- #define PLATFORM\_AR\_RELEASE\_MAJOR\_VERSION (4U)
- #define PLATFORM\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define **PLATFORM\_AR\_RELEASE\_PATCH\_VERSION** (3U)
- #define **CPU TYPE 8** (8U)
- #define **CPU\_TYPE\_16** (16U)
- #define **CPU\_TYPE\_32** (32U)
- #define **MSB\_FIRST** (0u) /\* Big endian bit ordering \*/
- #define LSB\_FIRST (1u) /\* Little endian bit ordering \*/
- #define **HIGH\_BYTE\_FIRST** (0u) /\* Big endian byte ordering \*/
- #define **LOW\_BYTE\_FIRST** (1u) /\* Little endian byte ordering \*/
- #define CPU\_TYPE CPU\_TYPE\_32
- #define CPU\_BIT\_ORDER LSB\_FIRST
- #define CPU\_BYTE\_ORDER LOW\_BYTE\_FIRST
- #define **FALSE** (0u)
- #define **TRUE** (1u)

### **Typedefs**

- typedef unsigned char boolean
- typedef unsigned char uint8
- typedef signed char sint8
- typedef unsigned short uint16
- typedef signed short sint16
- typedef unsigned long **uint32**
- typedef signed long **sint32**
- typedef unsigned long long uint64
- typedef signed long long sint64
- typedef float **float32**
- typedef double float64

### **Macro Definition Documentation**

```
#define CPU BIT ORDER LSB FIRST
#define CPU_BYTE_ORDER LOW_BYTE_FIRST
#define CPU_TYPE CPU_TYPE_32
#define CPU_TYPE_16 (16U)
#define CPU_TYPE_32 (32U)
#define CPU_TYPE_8 (8U)
#define FALSE (0u)
#define HIGH_BYTE_FIRST (0u) /* Big endian byte ordering
                                                             */
#define LOW_BYTE_FIRST (1u) /* Little endian byte ordering
                                                           */
#define LSB FIRST (1u) /* Little endian bit ordering
                                                     */
#define MSB_FIRST (0u)
                         /* Big endian bit ordering
                                                      */
#define PLATFORM_AR_RELEASE_MAJOR_VERSION (4U)
#define PLATFORM_AR_RELEASE_MINOR_VERSION (0U)
#define PLATFORM_AR_RELEASE_PATCH_VERSION (3U)
#define PLATFORM SW MAJOR VERSION (1U)
#define PLATFORM_SW_MINOR_VERSION (0U)
#define PLATFORM_SW_PATCH_VERSION (0U)
#define PLATFORM_VENDOR_ID (1000U)
#define TRUE (1u)
```

# **Typedef Documentation**

typedef unsigned char boolean

typedef float float32

typedef double float64

typedef signed short sint16

typedef signed long sint32

typedef signed long long sint64

typedef signed char sint8

typedef unsigned short uint16

typedef unsigned long uint32

typedef unsigned long long uint64

typedef unsigned char uint8

## Port.c File Reference

```
#include "Port.h"
#include "Port_Reg.h"
#include "Det.h"
```

Include dependency graph for Port.c:



### **Functions**

- void **Port\_Init** (const **Port\_ConfigType** \*ConfigPtr) *Function to initialize the port driver Module.*
- void **Port\_SetPinDirection** (**Port\_PinType** Pin, **Port\_PinDirectionType** Direction) *Function that sets the port pin direction.*
- void Port\_RefreshPortDirection (void)
   Function used to refresh the direction of all configured ports to configured direction.
- void **Port\_GetVersionInfo** (**Std\_VersionInfoType** \*versioninfo) *Function to get the version information of this module.*
- void **Port\_SetPinMode** (**Port\_PinType** Pin, **Port\_PinModeType** Mode) Function used to set port pin mode during run time.

# **Variables**

- STATIC uint8 Port\_Status = PORT\_NOT\_INITIALIZED
- const STATIC Port\_ConfigChannel \* Port\_Channels = NULL\_PTR

#### **Function Documentation**

void Port\_GetVersionInfo (Std\_VersionInfoType \* versioninfo)

Function to get the version information of this module.

#### **Parameters**

| (in)    | VersionInfo - Pointer to where to store the version information of this module. |
|---------|---------------------------------------------------------------------------------|
| (inout) | None                                                                            |
| (out)   | None                                                                            |

### **Returns**

None

#### Note

This function can be deleted if PORT\_VERSION\_INFO\_API != STD\_ON

# void Port\_Init (const Port\_ConfigType \* ConfigPtr)

Function to initialize the port driver Module.

#### **Parameters**

| (in)    | ConfigPtr - Pointer to configuration set |
|---------|------------------------------------------|
| (inout) | None                                     |
| (out)   | None                                     |

### **Returns**

none

Here is the caller graph for this function:



## void Port\_RefreshPortDirection (void )

Function used to refresh the direction of all configured ports to configured direction.

### **Parameters**

| (in)    | None |
|---------|------|
| (inout) | None |
| (out)   | None |

## Returns

None

# void Port\_SetPinDirection (Port\_PinType Pin, Port\_PinDirectionType Direction)

Function that sets the port pin direction.

### **Parameters**

| (in)    | Pin - Port Pin ID Number       |
|---------|--------------------------------|
| (in)    | Direction - Port Pin Direction |
| (inout) | None                           |
| (out)   | None                           |

### **Returns**

None

## Note

This function can be deleted if PORT\_SET\_PIN\_DIRECTION\_API != STD\_ON Here is the call graph for this function:

## void Port\_SetPinMode (Port\_PinType Pin, Port\_PinModeType Mode)

Function used to set port pin mode during run time.

### **Parameters**

| (in)    | Pin - Port Pin ID Number                       |
|---------|------------------------------------------------|
| (in)    | Mode - New Port pin Mode to be set in port pin |
| (inout) | None                                           |
| (out)   | None                                           |

#### **Returns**

None

# **Variable Documentation**

const STATIC Port\_ConfigChannel\* Port\_Channels = NULL\_PTR

STATIC uint8 Port\_Status = PORT\_NOT\_INITIALIZED

## Port.h File Reference

#include "Std\_Types.h"
#include "Port\_Cfg.h"
#include "Common\_Macros.h"
Include dependency graph for Port.h:



This graph shows which files directly or indirectly include this file:



### **Data Structures**

- struct Port\_ConfigChannel

  Used to set the configurations of a Specific pin in Port Module.
- struct **Port\_ConfigType**This structure holds an array of structures that holds the configurations of the pins.

#### **Macros**

- #define **PORT\_VENDOR\_ID** (1024U)
- #define **PORT\_MODULE\_ID** (124U)
- #define **PORT\_INSTANCE\_ID** (0U)
- #define **PORT\_SW\_MAJOR\_VERSION** (1U)
- #define PORT\_SW\_MINOR\_VERSION (1U)
- #define **PORT\_SW\_PATCH\_VERSION** (2U)
- #define **PORT\_AR\_RELEASE\_MAJOR\_VERSION** (4U)
- #define **PORT\_AR\_RELEASE\_MINOR\_VERSION** (0U)
- #define PORT\_AR\_RELEASE\_PATCH\_VERSION (3U)
- #define **PORT\_INITIALIZED** (1U)
- #define **PORT NOT INITIALIZED** (0U)
- #define **PORT\_INIT\_SID** (**uint8**)0x00
- #define **PORT\_SET\_PIN\_DIRECTION\_SID** (**uint8**)0x01
- #define PORT\_REFRESH\_PORT\_DIRECTION\_SID (uint8)0x02
- #define **PORT\_GET\_VERSION\_INFO\_SID** (**uint8**)0x03
- #define **PORT\_SET\_PIN\_MODE\_SID** (**uint8**)0x04
- #define **PORT\_E\_PARAM\_PIN** (uint8)0x0A
- #define PORT\_E\_DIRECTION\_UNCHANGEABLE (uint8)0x0B
- #define PORT\_E\_PARAM\_CONFIG (uint8)0x0C

- #define PORT E PARAM INVALID MODE (uint8)0x0D
- #define PORT\_E\_MODE\_UNCHANGEABLE (uint8)0x0E
- #define **PORT\_E\_UNINIT** (**uint8**)0x0F
- #define **PORT\_E\_PARAM\_POINTER** (**uint8**)0x10
- #define PORT\_E\_DIRECTON\_UNCHANGEABLE (uint8)0x12
- #define PIN\_DIRECTION\_CHANGEABILITY\_ON STD\_ON
- #define PIN DIRECTION CHANGEABILITY OFF STD OFF
- #define PIN\_MODE\_CHANGEABILITY\_ON STD\_ON
- #define PIN MODE CHANGEABILITY OFF STD OFF
- #define INITIAL VALUE HIGH STD HIGH
- #define INITIAL\_VALUE\_LOW STD\_LOW
- #define ANALOG\_MODE\_SELECTED 15
- #define SLEW RATE ENABLE STD ON
- #define SLEW RATE DISABLE STD OFF
- #define **PORT\_C\_PIN\_0\_JTAG** (100U)
- #define **PORT\_C\_PIN\_1\_JTAG** (101U)
- #define PORT\_C\_PIN\_2\_JTAG (102U)
- #define **PORT\_C\_PIN\_3\_JTAG** (103U)
- #define PIN\_NUM\_MAX\_CHECK (40U)
- #define LOCK\_REGISTER\_UNLOCK\_VALUE (0x4C4F434B)
- #define **PORT CONTROL MASK VALUE** (0x0000000F)
- #define **PORT\_CONTROL\_BIT\_NUMBERS** (4U)

# **Typedefs**

• typedef uint8 Port\_PinType

Type definition for Port\_PinType used by PORT APIs Which used to decide which pin number is used.

typedef uint8 Port\_PinModeType

Type definition for Port\_PinModeType used by PORT APIs Which used to decide the mode of the Pin.

#### **Enumerations**

enum Port\_PinDirectionType { PORT\_PIN\_IN, PORT\_PIN\_OUT, PORT\_PIN\_DEFAULT }

Type definition for Port\_PinDirectionType used by PORT APIs.

- enum **Port\_InternalResistor** { **OFF**, **PULL\_UP**, **PULL\_DOWN** } *Used to decide the mode of internal pull up or to disable it at all.*
- enum **Port\_PinModeEnum** { **DIO\_PIN** = 0, **PORT\_A\_PIN\_0\_AF1\_U0RX** = 1,
  - $\mathbf{PORT\_A\_PIN\_1\_AF1\_U0TX} = 1, \mathbf{PORT\_B\_PIN\_0\_AF1\_U1RX} = 1,$
  - $PORT_B_PIN_1_AF1_U1TX = 1$ ,  $PORT_C_PIN_4_AF1_U4RX = 1$ ,
  - $\label{eq:port_cpin_f_af1_u4TX} \textbf{PORT_C_PIN_6\_AF1\_U3RX} = 1,$
  - **PORT\_C\_PIN\_7\_AF1\_U3TX** = 1, **PORT\_D\_PIN\_0\_AF1\_SSI3CLK** = 1,
  - $PORT_D_PIN_1_AF1_SSI3FSS = 1$ ,  $PORT_D_PIN_2_AF1_SSI3RX = 1$ ,
  - $PORT_D_PIN_3_AF1_SSI3TX = 1$ ,  $PORT_D_PIN_4_AF1_U6RX = 1$ ,
  - PORT D PIN 5 AF1 U6TX = 1, PORT D PIN 6 AF1 U2RX = 1,
  - $PORT_D_PIN_7_AF1_U2TX = 1$ ,  $PORT_E_PIN_0_AF1_U7RX = 1$ ,
  - $\mathbf{PORT\_E\_PIN\_1\_AF1\_U7TX} = 1, \ \mathbf{PORT\_E\_PIN\_4\_AF1\_U5RX} = 1,$
  - PORT\_E\_PIN\_5\_AF1\_U5TX = 1, PORT\_F\_PIN\_0\_AF1\_U1RTS = 1, PORT\_F\_PIN\_1\_AF1\_U1CTS = 1, PORT\_A\_PIN\_2\_AF2\_SSI0CLK = 2,
  - $PORT_A_PIN_3_AF2_SSI0FSS = 2$ ,  $PORT_A_PIN_4_AF2_SSI0RX = 2$ ,
  - $PORT_A_PIN_5_AF2_SSIOTX = 2$ ,  $PORT_B_PIN_4_AF2_SSI2CLK = 2$ ,
  - $PORT_B_PIN_5_AF2_SSI2FSS = 2$ ,  $PORT_B_PIN_6_AF2_SSI2RX = 2$ ,
  - $PORT_B_PIN_7_AF2_SSI2TX = 2$ ,  $PORT_C_PIN_4_AF2_U1RX = 2$ ,

```
PORT_C_PIN_5_AF2_U1TX = 2, PORT_D_PIN_0_AF2_SSI1CLK = 2,
PORT D PIN 1 AF2 SSI1FSS = 2, PORT D PIN 2 AF2 SSI1RX = 2,
PORT_D_PIN_3_AF2_SSI1TX = 2, PORT_F_PIN_0_AF2_SSI1RX = 2,
PORT_F_PIN_1_AF2_SSI1TX = 2, PORT_F_PIN_2_AF2_SSI1CLK = 2,
PORT_F_PIN_3_AF2_SSI1FSS = 2, PORT_A_PIN_6_AF3_I2C1SCL = 3,
PORT_A_PIN_7_AF3_I2C1SDA = 3, PORT_B_PIN_2_AF3_I2C0SCL = 3,
PORT_B_PIN_3_AF3_I2C0SDA = 3, PORT_D_PIN_0_AF3_I2C3SCL = 3,
PORT_D_PIN_1_AF3_I2C3SDA = 3, PORT_E_PIN_4_AF3_I2C2SCL = 3,
PORT_E_PIN_5_AF3_I2C2SDA = 3, PORT_F_PIN_0_AF3_CAN0RX = 3,
PORT F PIN 3 AF3 CANOTX = 3, PORT B PIN 4 AF4 M0PWM2 = 4,
PORT B PIN 5 AF4 M0PWM3 = 4, PORT B PIN 6 AF4 M0PWM0 = 4,
PORT B PIN 7 AF4 M0PWM1 = 4, PORT C PIN 4 AF4 M0PWM6 = 4,
PORT C PIN 5 AF4 M0PWM7 = 4, PORT D PIN 0 AF4 M0PWM6 = 4,
PORT D PIN 1 AF4 M0PWM7 = 4. PORT D PIN 2 AF4 M0FAULT0 = 4.
PORT_D_PIN_6_AF4_M0FAULT0 = 4, PORT_E_PIN_4_AF4_M0PWM4 = 4.
PORT_E_PIN_5_AF4_M0PWM5 = 4, PORT_F_PIN_2_AF4_M0FAULT0 = 4,
PORT_A_PIN_6_AF5_M1PWM2 = 5, PORT_A_PIN_7_AF5_M1PWM3 = 5,
PORT_D_PIN_0_AF5_M1PWM0 = 5, PORT_D_PIN_1_AF5_M1PWM1 = 5,
PORT_E_PIN_4_AF5_M1PWM2 = 5, PORT_E_PIN_5_AF5_M1PWM3 = 5,
PORT_F_PIN_0_AF5_M1PWM4 = 5, PORT_F_PIN_1_AF5_M1PWM5 = 5,
PORT_F_PIN_2_AF5_M1PWM6 = 5, PORT_F_PIN_3_AF5_M1PWM7 = 5,
PORT_F_PIN_4\_AF5\_M1FAULT0 = 5, PORT_C_PIN_4\_AF6\_IDX1 = 6,
PORT_C_PIN_5_AF6_PHA1 = 6, PORT_C_PIN_6_AF6_PHB1 = 6,
PORT_D_PIN_3_AF6_IDX0 = 6, PORT_D_PIN_6_AF6_PHA0 = 6,
\label{eq:port_pin_port} \textbf{PORT}\_\textbf{D}\_\textbf{PIN}\_\textbf{7}\_\textbf{AF6}\_\textbf{PHB0} = 6, \\ \textbf{PORT}\_\textbf{F}\_\textbf{PIN}\_\textbf{0}\_\textbf{AF6}\_\textbf{PHA0} = 6, \\ \textbf{PORT}\_\textbf{F}\_\textbf{PIN}\_\textbf{0}\_\textbf{AF6}\_\textbf{PHA0} = 6, \\ \\ \textbf{PORT}\_\textbf{0}\_\textbf{0}\_\textbf{0} = 6, \\ \\ \textbf{PORT}\_\textbf{0}\_\textbf{0} = 6, \\ \\ \textbf{PORT}\_\textbf{0}\_\textbf{0} = 6, \\ \\ \textbf{PORT}\_\textbf{0} = 6, \\ \\ \textbf{0} = 6, \\
PORT_F_PIN_1_AF6_PHB0 = 6, PORT_F_PIN_4_AF6_IDX0 = 6,
PORT_B_PIN_0_AF7_T2CCP0 = 7, PORT_B_PIN_1_AF7_T2CCP1 = 7,
PORT_B_PIN_2_AF7_T3CCP0 = 7, PORT_B_PIN_3_AF7_T3CCP1 = 7,
PORT B PIN 4 AF7 T1CCP0 = 7, PORT B PIN 5 AF7 T1CCP1 = 7,
PORT_B_PIN_6_AF7_T0CCP0 = 7, PORT_B_PIN_7_AF7_T0CCP1 = 7,
PORT_C_PIN_4_AF7_WT0CCP0 = 7, PORT_C_PIN_5_AF7_WT0CCP1 = 7,
PORT C PIN 6 AF7 WT1CCP0 = 7, PORT C PIN 7 AF7 WT1CCP1 = 7,
PORT D PIN 0 AF7 WT2CCP0 = 7, PORT D PIN 1 AF7 WT2CCP1 = 7,
PORT D PIN 2 AF7 WT3CCP0 = 7, PORT D PIN 3 AF7 WT3CCP1 = 7,
PORT D PIN 4 AF7 WT4CCP0 = 7, PORT D PIN 5 AF7 WT4CCP1 = 7,
PORT_D_PIN_6_AF7_WT5CCP0 = 7, PORT_D_PIN_7_AF7_WT5CCP1 = 7,
PORT_F_PIN_0_AF7_T0CCP0 = 7, PORT_F_PIN_1_AF7_T0CCP1 = 7,
PORT_F_PIN_2_AF7_T1CCP0 = 7, PORT_F_PIN_3_AF7_T1CCP1 = 7,
PORT_F_PIN_4_AF7_T2CCP0 = 7, PORT_A_PIN_0_AF8_CAN1RX = 8,
PORT_A_PIN_1_AF8_CAN1TX = 8, PORT_B_PIN_4_AF8_CAN0RX = 8,
PORT_B_PIN_5_AF8_CANOTX = 8, PORT_C_PIN_4_AF8_U1RTS = 8,
PORT_C_PIN_5_AF8_U1CTS = 8, PORT_C_PIN_6_AF8_USB0EPEN = 8,
PORT_C_PIN_7_AF8_USB0PFLT = 8, PORT_D_PIN_2_AF8_USB0EPEN = 8,
PORT_D_PIN_3_AF8_USBOPFLT = 8, PORT_D_PIN_7_AF8_NMI = 8,
PORT_E_PIN_4_AF8_CANORX = 8, PORT_E_PIN_5_AF8_CANOTX = 8,
\mathbf{PORT\_F\_PIN\_0\_AF8\_NMI} = 8, \ \mathbf{PORT\_F\_PIN\_4\_AF8\_USB0EPEN} = 8,
PORT_F_PIN_0_AF9_COO = 9, PORT_F_PIN_1_AF9_CO1 = 9,
PORT_F_PIN_1_AF14_TRD1 = 14, PORT_F_PIN_2_AF14_TRD0 = 14,
PORT_F_PIN_3_AF14_TRCLK = 14 }
This enum has all the alternative function values of the TM4C123GH6PM to be used with
Port PinModeType data type.
enum Port_PinNumEnum { PORT_A_PIN_0 = 0, PORT_A_PIN_1 = 1, PORT_A_PIN_2 = 2,
PORT_A_PIN_3 = 3, PORT_A_PIN_4 = 4, PORT_A_PIN_5 = 5, PORT_A_PIN_6 = 6,
PORT_A_PIN_7 = 7, PORT_B_PIN_0 = 0, PORT_B_PIN_1 = 1, PORT_B_PIN_2 = 2,
PORT_B_PIN_3 = 3, PORT_B_PIN_4 = 4, PORT_B_PIN_5 = 5, PORT_B_PIN_6 = 6,
PORT B PIN 7 = 7, PORT C PIN 4 = 4, PORT C PIN 5 = 5, PORT C PIN 6 = 6,
PORT C PIN 7 = 7, PORT D PIN 0 = 0, PORT D PIN 1 = 1, PORT D PIN 2 = 2,
PORT_D_PIN_3 = 3, PORT_D_PIN_4 = 4, PORT_D_PIN_5 = 5, PORT_D_PIN_6 = 6,
PORT D PIN 7 = 7, PORT E PIN 0 = 0, PORT E PIN 1 = 1, PORT E PIN 2 = 2,
```

**PORT\_E\_PIN\_3** = 3, **PORT\_E\_PIN\_4** = 4, **PORT\_E\_PIN\_5** = 5, **PORT\_F\_PIN\_0** = 0, **PORT\_F\_PIN\_1** = 1, **PORT\_F\_PIN\_2** = 2, **PORT\_F\_PIN\_3** = 3, **PORT\_F\_PIN\_4** = 4 } *This enum used to numbering the pins on the TM4C123GH6PM.* 

• enum **Port\_PortNumEnum** { **PORTA**, **PORTB**, **PORTC**, **PORTD**, **PORTE**, **PORTF** } Used to decide the Port Number.

## **Functions**

- void Port\_Init (const Port\_ConfigType \*ConfigPtr)
   Function to initialize the port driver Module.
- void **Port\_SetPinDirection** (**Port\_PinType** Pin, **Port\_PinDirectionType** Direction) *Function that sets the port pin direction.*
- void **Port\_RefreshPortDirection** (void)

  Function used to refresh the direction of all configured ports to configured direction.
- void **Port\_GetVersionInfo** (**Std\_VersionInfoType** \*versioninfo) *Function to get the version information of this module.*
- void **Port\_SetPinMode** (**Port\_PinType** Pin, **Port\_PinModeType** Mode) Function used to set port pin mode during run time.

## **Variables**

• const Port\_ConfigType Port\_Configuration

#### **Macro Definition Documentation**

#define ANALOG MODE SELECTED 15

#define INITIAL\_VALUE\_HIGH STD\_HIGH

#define INITIAL\_VALUE\_LOW STD\_LOW

#define LOCK\_REGISTER\_UNLOCK\_VALUE (0x4C4F434B)

#define PIN\_DIRECTION\_CHANGEABILITY\_OFF STD\_OFF

#define PIN\_DIRECTION\_CHANGEABILITY\_ON STD\_ON

#define PIN\_MODE\_CHANGEABILITY\_OFF STD\_OFF

#define PIN\_MODE\_CHANGEABILITY\_ON STD\_ON

#define PIN\_NUM\_MAX\_CHECK (40U)

#define PORT\_AR\_RELEASE\_MAJOR\_VERSION (4U)

#define PORT\_AR\_RELEASE\_MINOR\_VERSION (0U)

#define PORT\_AR\_RELEASE\_PATCH\_VERSION (3U)

#define PORT\_C\_PIN\_0\_JTAG (100U)

#define PORT\_C\_PIN\_1\_JTAG (101U)

#define PORT C PIN 2 JTAG (102U)

#define PORT\_C\_PIN\_3\_JTAG (103U)

#define PORT\_CONTROL\_BIT\_NUMBERS (4U)

#define PORT\_CONTROL\_MASK\_VALUE (0x0000000F)

#define PORT\_E\_DIRECTION\_UNCHANGEABLE (uint8)0x0B

#define PORT\_E\_DIRECTON\_UNCHANGEABLE (uint8)0x12

#define PORT\_E\_MODE\_UNCHANGEABLE (uint8)0x0E

#define PORT\_E\_PARAM\_CONFIG (uint8)0x0C

#define PORT\_E\_PARAM\_INVALID\_MODE (uint8)0x0D

#define PORT\_E\_PARAM\_PIN (uint8)0x0A

#define PORT\_E\_PARAM\_POINTER (uint8)0x10

```
#define PORT_E_UNINIT (uint8)0x0F
#define PORT_GET_VERSION_INFO_SID (uint8)0x03
#define PORT_INIT_SID (uint8)0x00
#define PORT_INITIALIZED (1U)
#define PORT_INSTANCE_ID (0U)
#define PORT_MODULE_ID (124U)
#define PORT_NOT_INITIALIZED (0U)
#define PORT_REFRESH_PORT_DIRECTION_SID (uint8)0x02
#define PORT_SET_PIN_DIRECTION_SID (uint8)0x01
#define PORT_SET_PIN_MODE_SID (uint8)0x04
#define PORT_SW_MAJOR_VERSION (1U)
#define PORT_SW_MINOR_VERSION (1U)
#define PORT_SW_PATCH_VERSION (2U)
#define PORT_VENDOR_ID (1024U)
#define SLEW_RATE_DISABLE STD_OFF
#define SLEW_RATE_ENABLE STD_ON
```

## **Typedef Documentation**

#### Port\_PinModeType

Type definition for Port\_PinModeType used by PORT APIs Which used to decide the mode of the Pin.

#### Note

You can find these values Port\_PinModeEnum

#### Port\_PinType

Type definition for Port\_PinType used by PORT APIs Which used to decide which pin number is used.

#### Note

You can find these values @Port\_PinNumEnum

# **Enumeration Type Documentation**

# enum Port\_InternalResistor

Used to decide the mode of internal pull up or to disable it at all.

## **Enumerator:**

| OFF       | OFF.       |
|-----------|------------|
| DITT IID  |            |
| PULL_UP   | PULL_UP.   |
|           |            |
| PULL_DOWN | PULL_DOWN. |
|           |            |

# enum Port\_PinDirectionType

Type definition for Port\_PinDirectionType used by PORT APIs.

### **Enumerator:**

| PORT_PIN_IN          | PORT_PIN_IN.      |
|----------------------|-------------------|
| PORT_PIN_OUT         | PORT_PIN_OUT.     |
| PORT_PIN_DEF<br>AULT | PORT_PIN_DEFAULT. |

# enum Port\_PinModeEnum

This enum has all the alternative function values of the TM4C123GH6PM to be used with Port\_PinModeType data type.

### **Enumerator:**

| DIO_PIN                   | DIO_PIN.               |
|---------------------------|------------------------|
| PORT_A_PIN_0_<br>AF1_U0RX | PORT_A_PIN_0_AF1_U0RX. |
| PORT_A_PIN_1_<br>AF1_U0TX | PORT_A_PIN_1_AF1_U0TX. |
| PORT_B_PIN_0_<br>AF1_U1RX | PORT_B_PIN_0_AF1_U1RX. |
| PORT_B_PIN_1_<br>AF1_U1TX | PORT_B_PIN_1_AF1_U1TX. |
| PORT_C_PIN_4_<br>AF1_U4RX | PORT_C_PIN_4_AF1_U4RX. |
| PORT_C_PIN_5_             | PORT_C_PIN_5_AF1_U4TX. |

| A E1 TIATEX                  |                           |
|------------------------------|---------------------------|
| AF1_U4TX                     | DODE G DRY ( API YADY)    |
| PORT_C_PIN_6_<br>AF1_U3RX    | PORT_C_PIN_6_AF1_U3RX.    |
| PORT_C_PIN_7_<br>AF1_U3TX    | PORT_C_PIN_7_AF1_U3TX.    |
| PORT_D_PIN_0_<br>AF1_SSI3CLK | PORT_D_PIN_0_AF1_SSI3CLK. |
| PORT_D_PIN_1_<br>AF1_SSI3FSS | PORT_D_PIN_1_AF1_SSI3FSS. |
| PORT_D_PIN_2_<br>AF1_SSI3RX  | PORT_D_PIN_2_AF1_SSI3RX.  |
| PORT_D_PIN_3_<br>AF1_SSI3TX  | PORT_D_PIN_3_AF1_SSI3TX.  |
| PORT_D_PIN_4_<br>AF1_U6RX    | PORT_D_PIN_4_AF1_U6RX.    |
| PORT_D_PIN_5_<br>AF1_U6TX    | PORT_D_PIN_5_AF1_U6TX.    |
| PORT_D_PIN_6_<br>AF1_U2RX    | PORT_D_PIN_6_AF1_U2RX.    |
| PORT_D_PIN_7_<br>AF1_U2TX    | PORT_D_PIN_7_AF1_U2TX.    |
| PORT_E_PIN_0_<br>AF1_U7RX    | PORT_E_PIN_0_AF1_U7RX.    |
| PORT_E_PIN_1_<br>AF1_U7TX    | PORT_E_PIN_1_AF1_U7TX.    |
| PORT_E_PIN_4_<br>AF1_U5RX    | PORT_E_PIN_4_AF1_U5RX.    |
| PORT_E_PIN_5_<br>AF1_U5TX    | PORT_E_PIN_5_AF1_U5TX.    |
| PORT_F_PIN_0_<br>AF1_U1RTS   | PORT_F_PIN_0_AF1_U1RTS.   |
| PORT_F_PIN_1_<br>AF1_U1CTS   | PORT_F_PIN_1_AF1_U1CTS.   |
| PORT_A_PIN_2_<br>AF2_SSI0CLK | PORT_A_PIN_2_AF2_SSI0CLK. |
| PORT_A_PIN_3_<br>AF2_SSI0FSS | PORT_A_PIN_3_AF2_SSI0FSS. |
| PORT_A_PIN_4_<br>AF2_SSI0RX  | PORT_A_PIN_4_AF2_SSI0RX.  |
| PORT_A_PIN_5_<br>AF2_SSI0TX  | PORT_A_PIN_5_AF2_SSI0TX.  |
| PORT_B_PIN_4_<br>AF2_SSI2CLK | PORT_B_PIN_4_AF2_SSI2CLK. |
| PORT_B_PIN_5_<br>AF2_SSI2FSS | PORT_B_PIN_5_AF2_SSI2FSS. |
| PORT_B_PIN_6_<br>AF2_SSI2RX  | PORT_B_PIN_6_AF2_SSI2RX.  |
|                              |                           |

| PORT_B_PIN_7_<br>AF2_SSI2TX  | PORT_B_PIN_7_AF2_SSI2TX.  |
|------------------------------|---------------------------|
| PORT_C_PIN_4_<br>AF2_U1RX    | PORT_C_PIN_4_AF2_U1RX.    |
| PORT_C_PIN_5_<br>AF2_U1TX    | PORT_C_PIN_5_AF2_U1TX.    |
| PORT_D_PIN_0_<br>AF2_SSI1CLK | PORT_D_PIN_0_AF2_SSI1CLK. |
| PORT_D_PIN_1_<br>AF2_SSI1FSS | PORT_D_PIN_1_AF2_SSI1FSS. |
| PORT_D_PIN_2_<br>AF2_SSI1RX  | PORT_D_PIN_2_AF2_SSI1RX.  |
| PORT_D_PIN_3_<br>AF2_SSI1TX  | PORT_D_PIN_3_AF2_SSI1TX.  |
| PORT_F_PIN_0_<br>AF2_SSI1RX  | PORT_F_PIN_0_AF2_SSI1RX.  |
| PORT_F_PIN_1_<br>AF2_SSI1TX  | PORT_F_PIN_1_AF2_SSI1TX.  |
| PORT_F_PIN_2_<br>AF2_SSI1CLK | PORT_F_PIN_2_AF2_SSI1CLK. |
| PORT_F_PIN_3_<br>AF2_SSI1FSS | PORT_F_PIN_3_AF2_SSI1FSS. |
| PORT_A_PIN_6_<br>AF3_I2C1SCL | PORT_A_PIN_6_AF3_I2C1SCL. |
| PORT_A_PIN_7_<br>AF3_I2C1SDA | PORT_A_PIN_7_AF3_I2C1SDA. |
| PORT_B_PIN_2_<br>AF3_I2C0SCL | PORT_B_PIN_2_AF3_I2C0SCL. |
| PORT_B_PIN_3_<br>AF3_I2C0SDA | PORT_B_PIN_3_AF3_I2C0SDA. |
| PORT_D_PIN_0_<br>AF3_I2C3SCL | PORT_D_PIN_0_AF3_I2C3SCL. |
| PORT_D_PIN_1_<br>AF3_I2C3SDA | PORT_D_PIN_1_AF3_I2C3SDA. |
| PORT_E_PIN_4_<br>AF3_I2C2SCL | PORT_E_PIN_4_AF3_I2C2SCL. |
| PORT_E_PIN_5_<br>AF3_I2C2SDA | PORT_E_PIN_5_AF3_I2C2SDA. |
| PORT_F_PIN_0_<br>AF3_CAN0RX  | PORT_F_PIN_0_AF3_CAN0RX.  |
| PORT_F_PIN_3_<br>AF3_CAN0TX  | PORT_F_PIN_3_AF3_CAN0TX.  |
| PORT_B_PIN_4_<br>AF4_M0PWM2  | PORT_B_PIN_4_AF4_M0PWM2.  |
| PORT_B_PIN_5_<br>AF4_M0PWM3  | PORT_B_PIN_5_AF4_M0PWM3.  |
| PORT_B_PIN_6_<br>AF4_M0PWM0  | PORT_B_PIN_6_AF4_M0PWM0.  |

| PORT_B_PIN_7_<br>AF4_M0PWM1   | PORT_B_PIN_7_AF4_M0PWM1.   |
|-------------------------------|----------------------------|
| PORT_C_PIN_4_<br>AF4_M0PWM6   | PORT_C_PIN_4_AF4_M0PWM6.   |
| PORT_C_PIN_5_<br>AF4_M0PWM7   | PORT_C_PIN_5_AF4_M0PWM7.   |
| PORT_D_PIN_0_<br>AF4_M0PWM6   | PORT_D_PIN_0_AF4_M0PWM6.   |
| PORT_D_PIN_1_<br>AF4_M0PWM7   | PORT_D_PIN_1_AF4_M0PWM7.   |
| PORT_D_PIN_2_<br>AF4_M0FAULT0 | PORT_D_PIN_2_AF4_M0FAULT0. |
| PORT_D_PIN_6_<br>AF4_M0FAULT0 | PORT_D_PIN_6_AF4_M0FAULT0. |
| PORT_E_PIN_4_<br>AF4_M0PWM4   | PORT_E_PIN_4_AF4_M0PWM4.   |
| PORT_E_PIN_5_<br>AF4_M0PWM5   | PORT_E_PIN_5_AF4_M0PWM5.   |
| PORT_F_PIN_2_<br>AF4_M0FAULT0 | PORT_F_PIN_2_AF4_M0FAULT0. |
| PORT_A_PIN_6_<br>AF5_M1PWM2   | PORT_A_PIN_6_AF5_M1PWM2.   |
| PORT_A_PIN_7_<br>AF5_M1PWM3   | PORT_A_PIN_7_AF5_M1PWM3.   |
| PORT_D_PIN_0_<br>AF5_M1PWM0   | PORT_D_PIN_0_AF5_M1PWM0.   |
| PORT_D_PIN_1_<br>AF5_M1PWM1   | PORT_D_PIN_1_AF5_M1PWM1.   |
| PORT_E_PIN_4_<br>AF5_M1PWM2   | PORT_E_PIN_4_AF5_M1PWM2.   |
| PORT_E_PIN_5_<br>AF5_M1PWM3   | PORT_E_PIN_5_AF5_M1PWM3.   |
| PORT_F_PIN_0_<br>AF5_M1PWM4   | PORT_F_PIN_0_AF5_M1PWM4.   |
| PORT_F_PIN_1_<br>AF5_M1PWM5   | PORT_F_PIN_1_AF5_M1PWM5.   |
| PORT_F_PIN_2_<br>AF5_M1PWM6   | PORT_F_PIN_2_AF5_M1PWM6.   |
| PORT_F_PIN_3_<br>AF5_M1PWM7   | PORT_F_PIN_3_AF5_M1PWM7.   |
| PORT_F_PIN_4_<br>AF5_M1FAULT0 | PORT_F_PIN_4_AF5_M1FAULT0. |
| PORT_C_PIN_4_<br>AF6_IDX1     | PORT_C_PIN_4_AF6_IDX1.     |
| PORT_C_PIN_5_<br>AF6_PHA1     | PORT_C_PIN_5_AF6_PHA1.     |

| PORT_C_PIN_6_<br>AF6_PHB1    | PORT_C_PIN_6_AF6_PHB1.    |
|------------------------------|---------------------------|
| PORT_D_PIN_3_<br>AF6_IDX0    | PORT_D_PIN_3_AF6_IDX0.    |
| PORT_D_PIN_6_<br>AF6_PHA0    | PORT_D_PIN_6_AF6_PHA0.    |
| PORT_D_PIN_7_<br>AF6_PHB0    | PORT_D_PIN_7_AF6_PHB0.    |
| PORT_F_PIN_0_<br>AF6_PHA0    | PORT_F_PIN_0_AF6_PHA0.    |
| PORT_F_PIN_1_<br>AF6_PHB0    | PORT_F_PIN_1_AF6_PHB0.    |
| PORT_F_PIN_4_<br>AF6_IDX0    | PORT_F_PIN_4_AF6_IDX0.    |
| PORT_B_PIN_0_<br>AF7_T2CCP0  | PORT_B_PIN_0_AF7_T2CCP0.  |
| PORT_B_PIN_1_<br>AF7_T2CCP1  | PORT_B_PIN_1_AF7_T2CCP1.  |
| PORT_B_PIN_2_<br>AF7_T3CCP0  | PORT_B_PIN_2_AF7_T3CCP0.  |
| PORT_B_PIN_3_<br>AF7_T3CCP1  | PORT_B_PIN_3_AF7_T3CCP1.  |
| PORT_B_PIN_4_<br>AF7_T1CCP0  | PORT_B_PIN_4_AF7_T1CCP0.  |
| PORT_B_PIN_5_<br>AF7_T1CCP1  | PORT_B_PIN_5_AF7_T1CCP1.  |
| PORT_B_PIN_6_<br>AF7_T0CCP0  | PORT_B_PIN_6_AF7_T0CCP0.  |
| PORT_B_PIN_7_<br>AF7_T0CCP1  | PORT_B_PIN_7_AF7_T0CCP1.  |
| PORT_C_PIN_4_<br>AF7_WT0CCP0 | PORT_C_PIN_4_AF7_WT0CCP0. |
| PORT_C_PIN_5_<br>AF7_WT0CCP1 | PORT_C_PIN_5_AF7_WT0CCP1. |
| PORT_C_PIN_6_<br>AF7_WT1CCP0 | PORT_C_PIN_6_AF7_WT1CCP0. |
| PORT_C_PIN_7_<br>AF7_WT1CCP1 | PORT_C_PIN_7_AF7_WT1CCP1. |
| PORT_D_PIN_0_<br>AF7_WT2CCP0 | PORT_D_PIN_0_AF7_WT2CCP0. |
| PORT_D_PIN_1_<br>AF7_WT2CCP1 | PORT_D_PIN_1_AF7_WT2CCP1. |
| PORT_D_PIN_2_<br>AF7_WT3CCP0 | PORT_D_PIN_2_AF7_WT3CCP0. |
| PORT_D_PIN_3_<br>AF7_WT3CCP1 | PORT_D_PIN_3_AF7_WT3CCP1. |
| PORT_D_PIN_4_<br>AF7_WT4CCP0 | PORT_D_PIN_4_AF7_WT4CCP0. |

| PORT_D_PIN.5_ AF7_WT4CCP1  PORT_D_PIN.6_ AF7_WT5CCP0  PORT_D_PIN.7_ AF7_WT5CCP0  PORT_D_PIN.7_ AF7_WT5CCP1  PORT_D_PIN.7_ AF7_WT5CCP1  PORT_D_PIN.7_ AF7_WT5CCP1  PORT_D_PIN.7_ AF7_WT5CCP1  PORT_D_PIN.7_ AF7_WT5CCP1  PORT_F_PIN.1_ AF7_T0CCP0  PORT_F_PIN.1_ AF7_T0CCP1  PORT_F_PIN.2_ AF7_T1CCP0  PORT_F_PIN.3_ AF7_T1CCP1  PORT_F_PIN.4_ AF7_T2CCP0  PORT_F_PIN.4_ AF7_T2CCP0  PORT_A_PIN.0_ AF8_CANIRX  PORT_A_PIN.1_ AF8_CANIRX  PORT_A_PIN.1_ AF8_CANIRX  PORT_A_PIN.1_ AF8_CANIRX  PORT_B_PIN.4_ AF8_CANORX  PORT_B_PIN.5_ AF8_CANORX  PORT_B_PIN.5_ AF8_CANORX  PORT_B_PIN.5_ AF8_UIRTS  PORT_C_PIN.5_ AF8_UIRTS  PORT_C_PIN.5_ AF8_UICTS  PORT_C_PIN.6_ AF8_USB0EPEN  PORT_D_PIN.7_ AF8_USB0EPEN  PORT_D_PIN.7_ AF8_NMI  PORT_D_PIN.7_ AF8_NMI  PORT_B_PIN.4_ AF8_CANORX  PORT_B_PIN.5_ AF8_CANORX  PORT_D_PIN.7_ AF8_NMI  PORT_D_PIN.7_ AF8_NMI  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_D_PIN.7_ AF8_NMI  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_D_PIN.7_ AF8_NMI  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_D_PIN.7_ AF8_NMI  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_E_PIN.4_ AF8_USB0EPEN  PORT_F_PIN.4_ AF8_USB0EPEN   |                               |                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------------|
| AFT_WTSCCP0  PORT D_PIN.7_ AF7_WTSCCP1  PORT_PIN.0_ AF7_T0CCP0  PORT_F_PIN.0_ AF7_T0CCP1  PORT_F_PIN.1_ AF7_T0CCP1  PORT_F_PIN.2_ AF7_T1CCP0  PORT_F_PIN.3_ AF7_T1CCP1  PORT_F_PIN.3_ AF7_T1CCP1  PORT_F_PIN.4_ AF7_T2CCP0  PORT_A_PIN.0_ AF8_CANITX  PORT_A_PIN.1_ AF8_CANITX  PORT_A_PIN.1_ AF8_CANITX  PORT_B_PIN.4_ AF8_CANOTX  PORT_B_PIN.5_ AF8_CANOTX  PORT_B_PIN.5_ AF8_CANOTX  PORT_C_PIN.5_ AF8_UICTS  PORT_C_PIN.5_ AF8_UICTS  PORT_C_PIN.6_ AF8_UISTS  PORT_C_PIN.7_ AF8_USBOPELT  PORT_D_PIN.7_ AF8_USBOPELT  |                               | PORT_D_PIN_5_AF7_WT4CCP1.  |
| AF7_WTSCCPI  PORT_F_PIN_0_AF7_TOCCPO.  AF7_TOCCPO  PORT_F_PIN_1_AF7_TOCCPI.  AF7_TOCCPI  PORT_F_PIN_2_AF7_TICCPO.  PORT_F_PIN_3_AF7_TICCPO.  PORT_F_PIN_3_AF7_TICCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_F_PIN_4_AF7_TOCCPI.  PORT_A_PIN_0_AF8_CANIRX.  PORT_A_PIN_1_AF8_CANIRX.  PORT_A_PIN_1_AF8_CANITX.  PORT_B_PIN_4_AF8_CANITX.  PORT_B_PIN_5_AF8_CANORX.  PORT_B_PIN_5_AF8_CANORX.  PORT_B_PIN_5_AF8_UICTS.  PORT_C_PIN_4_AF8_UICTS.  PORT_C_PIN_5_AF8_UICTS.  PORT_C_PIN_6_AF8_UICTS.  PORT_C_PIN_7_AF8_UISBOEPEN.  PORT_C_PIN_7_AF8_USBOEPEN.  PORT_D_PIN_7_AF8_USBOEPEN.  PORT_D_PIN_7_AF8_USBOEPEN.  PORT_D_PIN_7_AF8_USBOEPEN.  PORT_D_PIN_3_AF8_USBOEPEN.  PORT_D_PIN_3_AF8_USBOEPEN.  PORT_D_PIN_3_AF8_USBOEPEN.  PORT_D_PIN_7_AF8_NMI.  PORT_E_PIN_4_AF8_CANORX.  PORT_E_PIN_4_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_E_PIN_5_AF8_CANORX.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_4_APF8_USBOEPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                               | PORT_D_PIN_6_AF7_WT5CCP0.  |
| AF7_TOCCPO  PORT_F_PIN_1_ AF7_TOCCPI  PORT_F_PIN_2_ AF7_TICCPO  PORT_F_PIN_3_ AF7_TICCPO  PORT_F_PIN_3_ AF7_TICCPO  PORT_F_PIN_4_ AF7_T2CCPO  PORT_F_PIN_4_ AF7_T2CCPO  PORT_A_PIN_0_ AF8_CANITX  PORT_A_PIN_1_ AF8_CANITX  PORT_B_PIN_4_ AF8_CANOX  PORT_B_PIN_4_ AF8_CANOX  PORT_B_PIN_5_ AF8_CANOX  PORT_B_PIN_5_ AF8_CANOTX  PORT_C_PIN_4_ AF8_UIRTS  PORT_C_PIN_5_ AF8_UICTS  PORT_C_PIN_5_ AF8_UICTS  PORT_C_PIN_6_ AF8_USBOPEN  PORT_D_PIN_7_ AF8_USBOPEN  PORT_D_PIN_7_ AF8_USBOPEN  PORT_D_PIN_3_ AF8_USBOPEN  PORT_D_PIN_5_AF8_CANORX  PORT_E_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ PORT_F_PIN_4_AF8_USBOEPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                               | PORT_D_PIN_7_AF7_WT5CCP1.  |
| AF7_TOCCPI  PORT_F_PIN_2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                               | PORT_F_PIN_0_AF7_T0CCP0.   |
| AF7_T1CCP0  PORT_F_PIN_3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                               | PORT_F_PIN_1_AF7_T0CCP1.   |
| AF7_TICCPI  PORT_F_PIN_4_ AF7_T2CCP0  PORT_A_PIN_0_ AF8_CANIRX  PORT_A_PIN_1_ AF8_CANITX  PORT_B_PIN_4_ AF8_CANOTX  PORT_B_PIN_4_ AF8_CANOTX  PORT_B_PIN_5_ AF8_CANOTX  PORT_C_PIN_4_ AF8_UICTS  PORT_C_PIN_6_ AF8_USB0EPEN  PORT_D_PIN_7_ AF8_USB0EPEN  PORT_D_PIN_3_ AF8_USB0EPEN  PORT_D_PIN_1_ AF8_NMI  PORT_B_PIN_5_ AF8_CANOTX  PORT_B_PIN_5_ AF8_CANOTX  PORT_B_PIN_5_ AF8_CANOTX  PORT_B_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ POR |                               | PORT_F_PIN_2_AF7_T1CCP0.   |
| AF7_T2CCP0  PORT_A_PIN_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                               | PORT_F_PIN_3_AF7_T1CCP1.   |
| AF8_CANIRX           PORT_A_PIN_1_AF8_CANITX           PORT_B_PIN_4_AF8_CANORX           PORT_B_PIN_4_AF8_CANORX           PORT_B_PIN_5_AF8_CANOTX           PORT_B_PIN_5_AF8_CANOTX           PORT_C_PIN_4_AF8_UIRTS           PORT_C_PIN_5_AF8_UICTS           PORT_C_PIN_5_AF8_UICTS           PORT_C_PIN_6_AF8_USBOEPEN           PORT_C_PIN_7_AF8_USBOEPEN           PORT_C_PIN_7_AF8_USBOEPEN           PORT_D_PIN_2_AF8_USBOEPEN           PORT_D_PIN_3_AF8_USBOEPEN           PORT_D_PIN_3_AF8_USBOEPEN           PORT_D_PIN_3_AF8_USBOEPEN           PORT_D_PIN_7_AF8_USBOEPEN           PORT_D_PIN_3_AF8_USBOEPEN           PORT_D_PIN_3_AF8_USBOEPEN           PORT_D_PIN_4_AF8_NMI           PORT_D_PIN_5_AF8_NMI           PORT_E_PIN_4_AF8_CANORX           PORT_E_PIN_5_AF8_CANOTX           PORT_F_PIN_0_AF8_NMI           PORT_F_PIN_0_AF8_NMI           PORT_F_PIN_0_AF8_NMI           PORT_F_PIN_4_PORT_F_PIN_4_AF8_USBOEPEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               | PORT_F_PIN_4_AF7_T2CCP0.   |
| PORT_B_PIN_4_AF8_CANORX.  PORT_B_PIN_5_AF8_CANOTX.  PORT_C_PIN_4_AF8_UIRTS.  PORT_C_PIN_5_AF8_UICTS.  PORT_C_PIN_6_AF8_UICTS.  PORT_C_PIN_6_AF8_USB0EPEN.  PORT_C_PIN_7_AF8_USB0EPEN.  PORT_C_PIN_7_AF8_USB0EPEN.  PORT_D_PIN_2_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_USB0EPEN.  PORT_D_PIN_5_AF8_CANOTX.  PORT_E_PIN_5_AF8_CANOTX.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                               | PORT_A_PIN_0_AF8_CAN1RX.   |
| AF8_CANORX         PORT_B_PIN_5_AF8_CANOTX.           PORT_C_PIN_4_AF8_UIRTS         PORT_C_PIN_4_AF8_UIRTS.           PORT_C_PIN_5_AF8_UICTS         PORT_C_PIN_5_AF8_UICTS.           PORT_C_PIN_6_AF8_USB0EPEN.         PORT_C_PIN_6_AF8_USB0EPEN.           AF8_USB0FLT         PORT_C_PIN_7_AF8_USB0FLT.           PORT_D_PIN_2_AF8_USB0EPEN.         PORT_D_PIN_2_AF8_USB0EPEN.           AF8_USB0FLT         PORT_D_PIN_3_AF8_USB0EPEN.           PORT_D_PIN_3_AF8_USB0FLT.         PORT_D_PIN_3_AF8_USB0FLT.           PORT_D_PIN_7_AF8_NMI.         PORT_D_PIN_7_AF8_NMI.           AF8_NMI         PORT_D_PIN_4_AF8_CANORX.           PORT_E_PIN_4_AF8_CANOTX         PORT_E_PIN_5_AF8_CANOTX.           PORT_F_PIN_0_AF8_NMI.         PORT_F_PIN_0_AF8_NMI.           PORT_F_PIN_4_AF8_NMI         PORT_F_PIN_0_AF8_NMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                               | PORT_A_PIN_1_AF8_CAN1TX.   |
| AF8_CANOTX         PORT_C_PIN_4<br>AF8_U1RTS         PORT_C_PIN_4_AF8_U1RTS.           PORT_C_PIN_5<br>AF8_U1CTS         PORT_C_PIN_5_AF8_U1CTS.           PORT_C_PIN_6<br>AF8_USB0EPEN         PORT_C_PIN_6_AF8_USB0EPEN.           PORT_C_PIN_7<br>AF8_USB0FLT         PORT_C_PIN_7_AF8_USB0FLT.           PORT_D_PIN_2<br>AF8_USB0EPEN         PORT_D_PIN_2_AF8_USB0EPEN.           PORT_D_PIN_3<br>AF8_USB0FLT         PORT_D_PIN_3_AF8_USB0FLT.           PORT_D_PIN_7<br>AF8_NMI         PORT_D_PIN_7_AF8_NMI.           PORT_E_PIN_4<br>AF8_CANORX         PORT_E_PIN_4_AF8_CANOTX.           PORT_E_PIN_5<br>AF8_CANOTX         PORT_E_PIN_0_AF8_NMI.           PORT_F_PIN_0<br>AF8_NMI         PORT_F_PIN_0_AF8_NMI.           PORT_F_PIN_4         PORT_F_PIN_0_AF8_NMI.           PORT_F_PIN_4         PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                               | PORT_B_PIN_4_AF8_CAN0RX.   |
| PORT_C_PIN_5_ AF8_U1CTS  PORT_C_PIN_6_ AF8_USB0EPEN  PORT_C_PIN_7_ AF8_USB0FFLT  PORT_D_PIN_2_ AF8_USB0EPEN  PORT_D_PIN_3_ AF8_USB0FFLT  PORT_D_PIN_3_ AF8_USB0FFLT  PORT_D_PIN_1_ AF8_USB0FFLT  PORT_D_PIN_3_ AF8_USB0FFLT  PORT_D_PIN_3_ AF8_USB0FFLT  PORT_D_PIN_1_ AF8_NMI  PORT_D_PIN_1_ AF8_NMI  PORT_E_PIN_4_ AF8_CANORX  PORT_E_PIN_5_ AF8_CANOTX  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                               | PORT_B_PIN_5_AF8_CAN0TX.   |
| PORT_C_PIN_6_AF8_USB0EPEN.  PORT_C_PIN_7_AF8_USB0EPEN.  PORT_C_PIN_7_AF8_USB0PFLT.  PORT_D_PIN_2_AF8_USB0EPEN.  PORT_D_PIN_2_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0PFLT.  PORT_D_PIN_7_AF8_NMI.  PORT_E_PIN_4_AF8_NMI.  PORT_E_PIN_4_AF8_CANORX.  PORT_E_PIN_5_AF8_CANOTX.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                               | PORT_C_PIN_4_AF8_U1RTS.    |
| PORT_C_PIN_7_ AF8_USB0PFLT  PORT_D_PIN_2_ AF8_USB0EPEN  PORT_D_PIN_2_ AF8_USB0EPEN  PORT_D_PIN_3_ AF8_USB0FLT  PORT_D_PIN_3_ AF8_USB0FLT  PORT_D_PIN_7_ AF8_NMI  PORT_E_PIN_4_ AF8_CAN0RX  PORT_E_PIN_5_ AF8_CAN0TX  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                               | PORT_C_PIN_5_AF8_U1CTS.    |
| PORT_D_PIN_2_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0EPEN.  PORT_D_PIN_3_AF8_USB0PFLT.  PORT_D_PIN_7_AF8_NMI.  PORT_D_PIN_7_AF8_NMI.  PORT_E_PIN_4_AF8_CANORX.  PORT_E_PIN_5_AF8_CANOTX.  PORT_E_PIN_5_AF8_CANOTX.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_0_AF8_NMI.  PORT_F_PIN_10_AF8_NMI.  PORT_F_PIN_10_AF8_NMI.  PORT_F_PIN_10_AF8_NMI.  PORT_F_PIN_10_AF8_NMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                               | PORT_C_PIN_6_AF8_USB0EPEN. |
| PORT_D_PIN_3_ AF8_USB0PFLT.  PORT_D_PIN_7_ AF8_NMI.  PORT_E_PIN_4_ AF8_CAN0RX.  PORT_E_PIN_5_ AF8_CAN0TX.  PORT_F_PIN_0_ AF8_NMI.  PORT_F_PIN_0_ AF8_NMI.  PORT_F_PIN_4_ PORT_F_PIN_0_ AF8_NMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               | PORT_C_PIN_7_AF8_USB0PFLT. |
| AF8_USB0PFLT  PORT_D_PIN_7_    AF8_NMI  PORT_E_PIN_4_    AF8_CAN0RX  PORT_E_PIN_5_    AF8_CAN0TX  PORT_F_PIN_0_    AF8_NMI  PORT_F_PIN_0_    AF8_NMI  PORT_F_PIN_4_    PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                               | PORT_D_PIN_2_AF8_USB0EPEN. |
| AF8_NMI  PORT_E_PIN_4_ AF8_CAN0RX  PORT_E_PIN_5_ AF8_CAN0TX  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ AF8_NMI  PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | I .                           | PORT_D_PIN_3_AF8_USB0PFLT. |
| AF8_CAN0RX  PORT_E_PIN_5_ AF8_CAN0TX  PORT_F_PIN_0_ AF8_NMI  PORT_F_PIN_4_ PORT_F_PIN_4_ PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                               | PORT_D_PIN_7_AF8_NMI.      |
| AF8_CAN0TX  PORT_F_PIN_0_    AF8_NMI  PORT_F_PIN_4_ PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                               | PORT_E_PIN_4_AF8_CAN0RX.   |
| AF8_NMI PORT_F_PIN_4_ PORT_F_PIN_4_AF8_USB0EPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                               | PORT_E_PIN_5_AF8_CAN0TX.   |
| 1 OK1_1_1 II \_ 1_I II \_ 0_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | I .                           | PORT_F_PIN_0_AF8_NMI.      |
| 14 0_000121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PORT_F_PIN_4_<br>AF8_USB0EPEN | PORT_F_PIN_4_AF8_USB0EPEN. |

| PORT_F_PIN_0_<br>AF9_C0O    | PORT_F_PIN_0_AF9_C0O.    |
|-----------------------------|--------------------------|
| PORT_F_PIN_1_<br>AF9_C01    | PORT_F_PIN_1_AF9_C01.    |
| PORT_F_PIN_1_<br>AF14_TRD1  | PORT_F_PIN_1_AF14_TRD1.  |
| PORT_F_PIN_2_<br>AF14_TRD0  | PORT_F_PIN_2_AF14_TRD0.  |
| PORT_F_PIN_3_<br>AF14_TRCLK | PORT_F_PIN_3_AF14_TRCLK. |

# enum Port\_PinNumEnum

This enum used to numbering the pins on the TM4C123GH6PM.

## **Enumerator:**

| chunierator. |               |  |
|--------------|---------------|--|
| PORT_A_PIN_0 | PORT_A_PIN_0. |  |
| PORT_A_PIN_1 | PORT_A_PIN_1. |  |
| PORT_A_PIN_2 | PORT_A_PIN_2. |  |
| PORT_A_PIN_3 | PORT_A_PIN_3. |  |
| PORT_A_PIN_4 | PORT_A_PIN_4. |  |
| PORT_A_PIN_5 | PORT_A_PIN_5. |  |
| PORT_A_PIN_6 | PORT_A_PIN_6. |  |
| PORT_A_PIN_7 | PORT_A_PIN_7. |  |
| PORT_B_PIN_0 | PORT_B_PIN_0. |  |
| PORT_B_PIN_1 | PORT_B_PIN_1. |  |
| PORT_B_PIN_2 | PORT_B_PIN_2. |  |
| PORT_B_PIN_3 | PORT_B_PIN_3. |  |
| PORT_B_PIN_4 | PORT_B_PIN_4. |  |
| PORT_B_PIN_5 | PORT_B_PIN_5. |  |
| PORT_B_PIN_6 | PORT_B_PIN_6. |  |
| PORT_B_PIN_7 | PORT_B_PIN_7. |  |

| PORT_C_PIN_4 | PORT_C_PIN_4. |
|--------------|---------------|
| PORT_C_PIN_5 | PORT_C_PIN_5. |
| PORT_C_PIN_6 | PORT_C_PIN_6. |
| PORT_C_PIN_7 | PORT_C_PIN_7. |
| PORT_D_PIN_0 | PORT_D_PIN_0. |
| PORT_D_PIN_1 | PORT_D_PIN_1. |
| PORT_D_PIN_2 | PORT_D_PIN_2. |
| PORT_D_PIN_3 | PORT_D_PIN_3. |
| PORT_D_PIN_4 | PORT_D_PIN_4. |
| PORT_D_PIN_5 | PORT_D_PIN_5. |
| PORT_D_PIN_6 | PORT_D_PIN_6. |
| PORT_D_PIN_7 | PORT_D_PIN_7. |
| PORT_E_PIN_0 | PORT_E_PIN_0. |
| PORT_E_PIN_1 | PORT_E_PIN_1. |
| PORT_E_PIN_2 | PORT_E_PIN_2. |
| PORT_E_PIN_3 | PORT_E_PIN_3. |
| PORT_E_PIN_4 | PORT_E_PIN_4. |
| PORT_E_PIN_5 | PORT_E_PIN_5. |
| PORT_F_PIN_0 | PORT_F_PIN_0. |
| PORT_F_PIN_1 | PORT_F_PIN_1. |
| PORT_F_PIN_2 | PORT_F_PIN_2. |
| PORT_F_PIN_3 | PORT_F_PIN_3. |
| PORT_F_PIN_4 | PORT_F_PIN_4. |
|              |               |

## enum Port\_PortNumEnum

Used to decide the Port Number.

### **Enumerator:**

| PORTA | PORTA. |
|-------|--------|
| PORTB | PORTB. |
| PORTC | PORTC. |
| PORTD | PORTD. |
| PORTE | PORTE. |
| PORTF | PORTF. |

## **Function Documentation**

# void Port\_GetVersionInfo (Std\_VersionInfoType \* versioninfo)

Function to get the version information of this module.

### **Parameters**

| (in)    | VersionInfo - Pointer to where to store the version information of this module. |
|---------|---------------------------------------------------------------------------------|
| (inout) | None                                                                            |
| (out)   | None                                                                            |

# Returns

None

### Note

This function can be deleted if PORT\_VERSION\_INFO\_API  $!= STD_ON$ 

# void Port\_Init (const Port\_ConfigType \* ConfigPtr)

Function to initialize the port driver Module.

### **Parameters**

| (in)    | ConfigPtr - Pointer to configuration set |
|---------|------------------------------------------|
| (inout) | None                                     |
| (out)   | None                                     |

### **Returns**

none



## void Port\_RefreshPortDirection (void )

Function used to refresh the direction of all configured ports to configured direction.

#### **Parameters**

| (in)    | None |  |
|---------|------|--|
| (inout) | None |  |
| (out)   | None |  |

#### **Returns**

None

# void Port\_SetPinDirection (Port\_PinType Pin, Port\_PinDirectionType Direction)

Function that sets the port pin direction.

#### **Parameters**

| (in)    | Pin - Port Pin ID Number       |
|---------|--------------------------------|
| (in)    | Direction - Port Pin Direction |
| (inout) | None                           |
| (out)   | None                           |

### **Returns**

None

#### Note

This function can be deleted if PORT\_SET\_PIN\_DIRECTION\_API != STD\_ON Here is the call graph for this function:



# void Port\_SetPinMode (Port\_PinType Pin, Port\_PinModeType Mode)

Function used to set port pin mode during run time.

### **Parameters**

| (in)    | Pin - Port Pin ID Number                       |
|---------|------------------------------------------------|
| (in)    | Mode - New Port pin Mode to be set in port pin |
| (inout) | None                                           |
| (out)   | None                                           |

### **Returns**

None

# **Variable Documentation**

const Port\_ConfigType Port\_Configuration

# Port\_Cfg.h File Reference

This graph shows which files directly or indirectly include this file:



### **Macros**

- #define PORT\_CFG\_SW\_MAJOR\_VERSION (1U)
- #define PORT\_CFG\_SW\_MINOR\_VERSION (1U)
- #define PORT\_CFG\_SW\_PATCH\_VERSION (2U)
- #define PORT\_CFG\_AR\_RELEASE\_MAJOR\_VERSION (4U)
- #define PORT\_CFG\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define PORT\_CFG\_AR\_RELEASE\_PATCH\_VERSION (3U)
- #define PORT\_DEV\_ERROR\_DETECT (STD\_ON)
- #define PORT\_SET\_PIN\_DIRECTION\_API (STD\_ON)
- #define PORT\_VERSION\_INFO\_API (STD\_ON)
- #define **PORT\_CONFIGURED\_CHANNLES** (39U)
- #define PortConf\_LED1\_PORT\_NUM (Port\_PortNumEnum)PORTF
- #define PortConf\_SW1\_PORT\_NUM (Port\_PortNumEnum)PORTF
- #define PortConf\_LED1\_PIN\_NUM (Port\_PinType)PORT\_F\_PIN\_2 /\* Pin 3 in PORTF \*/
- #define PortConf\_SW1\_PIN\_NUM (Port\_PinType)PORT\_F\_PIN\_4 /\* Pin 4 in PORTF \*/

### **Macro Definition Documentation**

```
#define PORT_CFG_AR_RELEASE_MAJOR_VERSION (4U)

#define PORT_CFG_AR_RELEASE_MINOR_VERSION (0U)

#define PORT_CFG_AR_RELEASE_PATCH_VERSION (3U)

#define PORT_CFG_SW_MAJOR_VERSION (1U)

#define PORT_CFG_SW_MINOR_VERSION (1U)

#define PORT_CFG_SW_PATCH_VERSION (2U)

#define PORT_CONFIGURED_CHANNLES (39U)

#define PORT_DEV_ERROR_DETECT (STD_ON)

#define PORT_SET_PIN_DIRECTION_API (STD_ON)

#define PORT_VERSION_INFO_API (STD_ON)

#define PortConf_LED1_PIN_NUM (Port_PinType)PORT_F_PIN_2 /* Pin 3 in PORTF */

#define PortConf_LED1_PORT_NUM (Port_PortNumEnum)PORTF

#define PortConf_SW1_PIN_NUM (Port_PinType)PORT_F_PIN_4 /* Pin 4 in PORTF */

#define PortConf_SW1_PIN_NUM (Port_PinType)PORT_F_PIN_4 /* Pin 4 in PORTF */
```

#define PortConf\_SW1\_PORT\_NUM (Port\_PortNumEnum)PORTF

# Port\_PBcfg.c File Reference

#include "Port.h"

Include dependency graph for Port\_PBcfg.c:



#### **Macros**

- #define **PORT\_PBCFG\_SW\_MAJOR\_VERSION** (1U)
- #define PORT\_PBCFG\_SW\_MINOR\_VERSION (1U)
- #define PORT PBCFG SW PATCH VERSION (2U)
- #define PORT PBCFG AR RELEASE MAJOR VERSION (4U)
- #define PORT\_PBCFG\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define PORT\_PBCFG\_AR\_RELEASE\_PATCH\_VERSION (3U)

### **Variables**

• const Port\_ConfigType Port\_Configuration

### **Macro Definition Documentation**

#define PORT\_PBCFG\_AR\_RELEASE\_MAJOR\_VERSION (4U)

#define PORT\_PBCFG\_AR\_RELEASE\_MINOR\_VERSION (0U)

#define PORT\_PBCFG\_AR\_RELEASE\_PATCH\_VERSION (3U)

#define PORT\_PBCFG\_SW\_MAJOR\_VERSION (1U)

#define PORT\_PBCFG\_SW\_MINOR\_VERSION (1U)

#define PORT\_PBCFG\_SW\_PATCH\_VERSION (2U)

# **Variable Documentation**

const Port\_ConfigType Port\_Configuration

# Port\_Reg.h File Reference

#include "Std\_Types.h"
#include "Common\_Macros.h"
Include dependency graph for Port\_Reg.h:



This graph shows which files directly or indirectly include this file:



### **Macros**

| <ul> <li>#define GPIO_PORTA_BASE_ADDRESS 0x40004000 /* GPIOA(APB) Base Address */</li> <li>#define GPIO_PORTB_BASE_ADDRESS 0x40005000 /* GPIOB(APB) Base Address */</li> <li>#define GPIO_PORTC_BASE_ADDRESS 0x40006000 /* GPIOC(APB) Base Address */</li> <li>#define GPIO_PORTD_BASE_ADDRESS 0x40007000 /* GPIOD(APB) Base Address */</li> <li>#define GPIO_PORTE_BASE_ADDRESS 0x40024000 /* GPIOE(APB) Base Address */</li> <li>#define GPIO_PORTE_BASE_ADDRESS 0x40025000 /* GPIOF(APB) Base Address */</li> <li>#define PORT_DATA_REG_OFFSET 0x3FC /* Data Register Offset */</li> <li>#define PORT_DIR_REG_OFFSET 0x400 /* Direction Register Offset */</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 /* Alternative Function Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable Register Offset */</li> </ul> |   | .0.00                         |      |                  |       |                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------|------|------------------|-------|----------------------------|
| <ul> <li>#define GPIO_PORTB_BASE_ADDRESS 0x40005000 /* GPIOB(APB) Base Address */</li> <li>#define GPIO_PORTC_BASE_ADDRESS 0x40006000 /* GPIOC(APB) Base Address */</li> <li>#define GPIO_PORTD_BASE_ADDRESS 0x40007000 /* GPIOD(APB) Base Address */</li> <li>#define GPIO_PORTE_BASE_ADDRESS 0x40024000 /* GPIOE(APB) Base Address */</li> <li>#define GPIO_PORTF_BASE_ADDRESS 0x40025000 /* GPIOF(APB) Base Address */</li> <li>#define PORT_DATA_REG_OFFSET 0x3FC /* Data Register Offset */</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 /* Alternative Function Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                 | • |                               | ESS  | 0x400040         | 00    | /* GPIOA(APB) Base Address |
| <ul> <li>#define GPIO_PORTC_BASE_ADDRESS 0x40006000 /* GPIOC(APB) Base Address */</li> <li>#define GPIO_PORTD_BASE_ADDRESS 0x40007000 /* GPIOD(APB) Base Address */</li> <li>#define GPIO_PORTE_BASE_ADDRESS 0x40024000 /* GPIOE(APB) Base Address */</li> <li>#define GPIO_PORTF_BASE_ADDRESS 0x40025000 /* GPIOF(APB) Base Address */</li> <li>#define PORT_DATA_REG_OFFSET 0x3FC /* Data Register Offset */</li> <li>#define PORT_DIR_REG_OFFSET 0x400 /* Direction Register Offset */</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 /* Alternative Function Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                        | • | #define GPIO_PORTB_BASE_ADDR  | ESS  | 0x400050         | 00    | /* GPIOB(APB) Base Address |
| <ul> <li>#/e #define GPIO_PORTE_BASE_ADDRESS 0x40024000 /* GPIOE(APB) Base Address // GPIOE(APB) Base Address // GPIOF(APB) Base Address // GPIOF(APB) Base Address // Data Register Offset // Data Register Offset // Data Register Offset // Direction Register Offset // Alternative Function Register Offset // Alternative Function Register Offset // Alternative Function // Pull Up Register Offset // Pull Up Register Offset // Pull Up Register Offset // Pull Down Register Offset // Pull Down Register Offset // Slew Rate control register offset // Slew Rate control register Offset // Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | • | #define GPIO_PORTC_BASE_ADDR  | ESS  | 0x400060         | 00    | /* GPIOC(APB) Base Address |
| <ul> <li>#define GPIO_PORTF_BASE_ADDRESS 0x40025000 /* GPIOF(APB) Base Address */</li> <li>#define PORT_DATA_REG_OFFSET 0x3FC /* Data Register Offset */</li> <li>#define PORT_DIR_REG_OFFSET 0x400 /* Direction Register Offset */</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 /* Alternative Function Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              | • |                               | ESS  | 0x400070         | 00    | /* GPIOD(APB) Base Address |
| <ul> <li>#define PORT_DATA_REG_OFFSET 0x3FC /* Data Register Offset //  #define PORT_DIR_REG_OFFSET 0x400 /* Direction Register Offset //  #define PORT_ALT_FUNC_REG_OFFSET 0x420 Register Offset */  #define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset //  #define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register /* Pull Down Register /* Pull Down Register /* Slew Rate control register offset /* Slew Rate control register offset /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | • |                               | ESS  | 0x400240         | 00    | /* GPIOE(APB) Base Address |
| <ul> <li>*/</li> <li>#define PORT_DIR_REG_OFFSET 0x400 /* Direction Register Offset */</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 /* Alternative Function Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset  */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset  */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | • |                               | ESS  | 0x4002500        | 00    | /* GPIOF(APB) Base Address |
| <ul> <li>*/</li> <li>#define PORT_ALT_FUNC_REG_OFFSET 0x420 Register Offset */</li> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | • |                               | Οx:  | 3FC              | /*    | Data Register Offset       |
| Register Offset */  #define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset  #define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register Offset */  #define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */  #define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | • |                               | 0x40 | 0                | /* Di | rection Register Offset    |
| <ul> <li>#define PORT_PULL_UP_REG_OFFSET 0x510 /* Pull Up Register Offset     */</li> <li>#define PORT_PULL_DOWN_REG_OFFSET 0x514 /* Pull Down Register     Offset */</li> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control     register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • |                               | FFSE | T 0x420          |       | /* Alternative Function    |
| Offset */  #define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */  #define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | • | #define PORT_PULL_UP_REG_OFF  | SET  | 0x510            |       | /* Pull Up Register Offset |
| <ul> <li>#define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 /* Slew Rate control register offset */</li> <li>#define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | • |                               | OFF  | <b>SET</b> 0x514 | 4     | /* Pull Down Register      |
| • #define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C /* Digital Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | • | #define PORT_SLEW_RATE_CONT   | ROL  | _OFFSET          | 0x518 | /* Slew Rate control       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | • | #define PORT_DIGITAL_ENABLE_1 | REG  | _OFFSET          | 0x51C | /* Digital Enable          |

- #define PORT\_LOCK\_REG\_OFFSET 0x520 /\* Lock Register Offset \*/
- #define PORT\_COMMIT\_REG\_OFFSET 0x524 /\* Commit Register Offset
   \*/
- #define PORT\_ANALOG\_MODE\_SEL\_REG\_OFFSET 0x528 /\* Analog mode selection Register Offset \*/
- #define PORT\_CTL\_REG\_OFFSET 0x52C /\* Control Register Offset \*/
- #define **SYSCTL\_REGCGC2\_REG** (\*((volatile **uint32** \*)0x400FE108))

# **Macro Definition Documentation**

| #define GPIO_PORTA_BASE_ADDRESS 0x40004000<br>Address */                      | /* GPIOA(APB) Base         |  |  |  |  |  |
|-------------------------------------------------------------------------------|----------------------------|--|--|--|--|--|
| #define GPIO_PORTB_BASE_ADDRESS 0x40005000<br>Address */                      | /* GPIOB(APB) Base         |  |  |  |  |  |
| #define GPIO_PORTC_BASE_ADDRESS 0x40006000<br>Address */                      | /* GPIOC(APB) Base         |  |  |  |  |  |
| #define GPIO_PORTD_BASE_ADDRESS 0x40007000 Address */                         | /* GPIOD(APB) Base         |  |  |  |  |  |
| #define GPIO_PORTE_BASE_ADDRESS 0x40024000<br>Address */                      | /* GPIOE(APB) Base         |  |  |  |  |  |
| #define GPIO_PORTF_BASE_ADDRESS 0x40025000<br>Address */                      | /* GPIOF(APB) Base         |  |  |  |  |  |
| #define PORT_ALT_FUNC_REG_OFFSET 0x420 Register Offset */                     | /* Alternative Function    |  |  |  |  |  |
| #define PORT_ANALOG_MODE_SEL_REG_OFFSET 0x! mode selection Register Offset */ | 528 /* Analog              |  |  |  |  |  |
| #define PORT_COMMIT_REG_OFFSET 0x524 */                                       | /* Commit Register Offset  |  |  |  |  |  |
| #define PORT_CTL_REG_OFFSET 0x52C /* */                                       | Control Register Offset    |  |  |  |  |  |
| #define PORT_DATA_REG_OFFSET 0x3FC */                                         | /* Data Register Offset    |  |  |  |  |  |
| #define PORT_DIGITAL_ENABLE_REG_OFFSET 0x51C Register Offset */               | /* Digital Enable          |  |  |  |  |  |
| #define PORT_DIR_REG_OFFSET 0x400 /* */                                       | Direction Register Offset  |  |  |  |  |  |
| #define PORT_LOCK_REG_OFFSET 0x520 */                                         | /* Lock Register Offset    |  |  |  |  |  |
| #define PORT_PULL_DOWN_REG_OFFSET 0x514 Offset */                             | /* Pull Down Register      |  |  |  |  |  |
| #define PORT_PULL_UP_REG_OFFSET 0x510 */                                      | /* Pull Up Register Offset |  |  |  |  |  |
| #define PORT_SLEW_RATE_CONTROL_OFFSET 0x518 control register offset */        | /* Slew Rate               |  |  |  |  |  |
| #define SYSCTL_REGCGC2_REG (*((volatile uint32 *)0x400FE108))                 |                            |  |  |  |  |  |

### Std\_Types.h File Reference

#include "Platform\_Types.h"
#include "Compiler.h"
Include dependency graph for Std\_Types.h:



This graph shows which files directly or indirectly include this file:



#### **Data Structures**

• struct Std\_VersionInfoType

#### **Macros**

- #define **STD\_TYPES\_VENDOR\_ID** (1000U)
- #define STD\_TYPES\_SW\_MAJOR\_VERSION (1U)
- #define **STD\_TYPES\_SW\_MINOR\_VERSION** (0U)
- #define STD\_TYPES\_SW\_PATCH\_VERSION (0U)
- #define STD\_TYPES\_AR\_RELEASE\_MAJOR\_VERSION (4U)
- #define STD\_TYPES\_AR\_RELEASE\_MINOR\_VERSION (0U)
- #define STD\_TYPES\_AR\_RELEASE\_PATCH\_VERSION (3U)
- #define **STD HIGH** 0x01U /\* Standard HIGH \*/
- #define **STD\_LOW** 0x00U /\* Standard LOW \*/
- #define STD\_ACTIVE 0x01U /\* Logical state active \*/
- #define **STD\_IDLE** 0x00U /\* Logical state idle \*/
- #define STD\_ON 0x01U /\* Standard ON \*/
- #define STD OFF 0x00U /\* Standard OFF \*/
- #define **E\_OK** ((**Std\_ReturnType**)0x00U) /\* Function Return OK \*/
- #define **E\_NOT\_OK** ((**Std\_ReturnType**)0x01U) /\* Function Return NOT OK \*/

#### **Typedefs**

• typedef uint8 Std\_ReturnType

#### **Macro Definition Documentation**

```
#define E_NOT_OK ((Std_ReturnType)0x01U)
                                            /* Function Return NOT OK */
#define E_OK ((Std_ReturnType)0x00U)
                                       /* Function Return OK */
#define STD_ACTIVE 0x01U
                              /* Logical state active */
#define STD_HIGH 0x01U
                            /* Standard HIGH */
#define STD_IDLE 0x00U
                           /* Logical state idle */
#define STD_LOW 0x00U
                           /* Standard LOW */
#define STD_OFF 0x00U
                           /* Standard OFF */
#define STD_ON 0x01U
                          /* Standard ON */
#define STD_TYPES_AR_RELEASE_MAJOR_VERSION (4U)
#define STD_TYPES_AR_RELEASE_MINOR_VERSION (0U)
#define STD_TYPES_AR_RELEASE_PATCH_VERSION (3U)
#define STD_TYPES_SW_MAJOR_VERSION (1U)
#define STD_TYPES_SW_MINOR_VERSION (0U)
#define STD_TYPES_SW_PATCH_VERSION (0U)
#define STD_TYPES_VENDOR_ID (1000U)
```

### **Typedef Documentation**

typedef uint8 Std\_ReturnType

### tm4c123gh6pm\_registers.h File Reference

#include "Std Types.h"

Include dependency graph for tm4c123gh6pm\_registers.h:



This graph shows which files directly or indirectly include this file:



#### **Macros**

- #define **GPIO\_PORTA\_DATA\_REG** (\*((volatile **uint32** \*)0x400043FC))
- #define GPIO PORTA DIR REG (\*((volatile uint32 \*)0x40004400))
- #define GPIO PORTA AFSEL REG (\*((volatile uint32 \*)0x40004420))
- #define **GPIO\_PORTA\_PUR\_REG** (\*((volatile **uint32** \*)0x40004510))
- #define **GPIO\_PORTA\_PDR\_REG** (\*((volatile **uint32** \*)0x40004514))
- #define **GPIO\_PORTA\_DEN\_REG** (\*((volatile **uint32** \*)0x4000451C))
- #define **GPIO\_PORTA\_LOCK\_REG** (\*((volatile **uint32** \*)0x40004520))
- #define **GPIO\_PORTA\_CR\_REG** (\*((volatile **uint32** \*)0x40004524))
- #define GPIO PORTA AMSEL REG (\*((volatile uint32 \*)0x40004528))
- #define **GPIO\_PORTA\_PCTL\_REG** (\*((volatile **uint32** \*)0x4000452C))
- #define **GPIO\_PORTA\_IS\_REG** (\*((volatile **uint32** \*)0x40004404))
- #define **GPIO\_PORTA\_IBE\_REG** (\*((volatile **uint32** \*)0x40004408))
- #define **GPIO\_PORTA\_IEV\_REG** (\*((volatile **uint32** \*)0x4000440C))
- #define **GPIO\_PORTA\_IM\_REG** (\*((volatile **uint32** \*)0x40004410))
- #define **GPIO\_PORTA\_RIS\_REG** (\*((volatile **uint32** \*)0x40004414))
- #define **GPIO\_PORTA\_ICR\_REG** (\*((volatile **uint32** \*)0x4000441C))
- #define **GPIO\_PORTB\_DATA\_REG** (\*((volatile **uint32** \*)0x400053FC))
- #define GPIO\_PORTB\_DIR\_REG (\*((volatile uint32 \*)0x40005400))
- #define GPIO PORTB AFSEL REG (\*((volatile uint32 \*)0x40005420))
- #define GPIO PORTB PUR REG (\*((volatile uint32 \*)0x40005510))
- #define **GPIO\_PORTB\_PDR\_REG** (\*((volatile **uint32** \*)0x40005514))
- #define GPIO\_PORTB\_DEN\_REG (\*((volatile uint32 \*)0x4000551C))
- #define **GPIO\_PORTB\_LOCK\_REG** (\*((volatile **uint32** \*)0x40005520))
- #define **GPIO\_PORTB\_CR\_REG** (\*((volatile **uint32** \*)0x40005524))
- #define **GPIO\_PORTB\_AMSEL\_REG** (\*((volatile **uint32** \*)0x40005528))
- #define GPIO\_PORTB\_PCTL\_REG (\*((volatile uint32 \*)0x4000552C))
- #define **GPIO\_PORTB\_IS\_REG** (\*((volatile **uint32** \*)0x40005404))
- #define GPIO\_PORTB\_IBE\_REG (\*((volatile uint32 \*)0x40005408))

```
• #define GPIO_PORTB_IEV_REG (*((volatile uint32 *)0x4000540C))
```

- #define **GPIO\_PORTB\_IM\_REG** (\*((volatile **uint32** \*)0x40005410))
- #define **GPIO\_PORTB\_RIS\_REG** (\*((volatile **uint32** \*)0x40005414))
- #define GPIO\_PORTB\_ICR\_REG (\*((volatile uint32 \*)0x4000541C))
- #define **GPIO\_PORTC\_DATA\_REG** (\*((volatile **uint32** \*)0x400063FC))
- #define GPIO PORTC DIR REG (\*((volatile uint32 \*)0x40006400))
- #define GPIO\_PORTC\_AFSEL\_REG (\*((volatile uint32 \*)0x40006420))
- #define GPIO\_PORTC\_PUR\_REG (\*((volatile uint32 \*)0x40006510))
- #define **GPIO\_PORTC\_PDR\_REG** (\*((volatile **uint32** \*)0x40006514))
- #define **GPIO\_PORTC\_DEN\_REG** (\*((volatile **uint32** \*)0x4000651C))
- #define **GPIO\_PORTC\_LOCK\_REG** (\*((volatile **uint32** \*)0x40006520))
- #define **GPIO\_PORTC\_CR\_REG** (\*((volatile **uint32** \*)0x40006524))
- #define GPIO\_PORTC\_AMSEL\_REG (\*((volatile uint32 \*)0x40006528))
- #define **GPIO\_PORTC\_PCTL\_REG** (\*((volatile **uint32** \*)0x4000652C))
- #define GPIO\_PORTC\_IS\_REG (\*((volatile uint32 \*)0x40006404))
- #define GPIO\_PORTC\_IBE\_REG (\*((volatile uint32 \*)0x40006408))
- #define GPIO\_PORTC\_IEV\_REG (\*((volatile uint32 \*)0x4000640C))
- #define **GPIO\_PORTC\_IM\_REG** (\*((volatile **uint32** \*)0x40006410))
- #define GPIO\_PORTC\_RIS\_REG (\*((volatile uint32 \*)0x40006414))
- #define GPIO\_PORTC\_ICR\_REG (\*((volatile uint32 \*)0x4000641C))
- #define GPIO\_PORTD\_DATA\_REG (\*((volatile uint32 \*)0x400073FC))
- #define GPIO\_PORTD\_DIR\_REG (\*((volatile uint32 \*)0x40007400))
- #define GPIO PORTD AFSEL REG (\*((volatile uint32 \*)0x40007420))
- #define GPIO\_PORTD\_PUR\_REG (\*((volatile uint32 \*)0x40007510))
- #define **GPIO\_PORTD\_PDR\_REG** (\*((volatile **uint32** \*)0x40007514))
- #define **GPIO\_PORTD\_DEN\_REG** (\*((volatile **uint32** \*)0x4000751C))
- #define GPIO\_PORTD\_LOCK\_REG (\*((volatile uint32 \*)0x40007520))
- #define **GPIO\_PORTD\_CR\_REG** (\*((volatile **uint32** \*)0x40007524))
- #define **GPIO\_PORTD\_AMSEL\_REG** (\*((volatile **uint32** \*)0x40007528))
- #define **GPIO\_PORTD\_PCTL\_REG** (\*((volatile **uint32** \*)0x4000752C))
- #define **GPIO\_PORTD\_IS\_REG** (\*((volatile **uint32** \*)0x40007404))
- #define **GPIO\_PORTD\_IBE\_REG** (\*((volatile **uint32** \*)0x40007408))
- #define **GPIO\_PORTD\_IEV\_REG** (\*((volatile **uint32** \*)0x4000740C))
- #define **GPIO\_PORTD\_IM\_REG** (\*((volatile **uint32** \*)0x40007410))
- #define **GPIO\_PORTD\_RIS\_REG** (\*((volatile **uint32** \*)0x40007414))
- #define **GPIO\_PORTD\_ICR\_REG** (\*((volatile **uint32** \*)0x4000741C))
- #define GPIO\_PORTE\_DATA\_REG (\*((volatile uint32 \*)0x400243FC))
- #define **GPIO\_PORTE\_DIR\_REG** (\*((volatile **uint32** \*)0x40024400))
- #define **GPIO\_PORTE\_AFSEL\_REG** (\*((volatile **uint32** \*)0x40024420))
- #define **GPIO\_PORTE\_PUR\_REG** (\*((volatile **uint32** \*)0x40024510))
- #define **GPIO\_PORTE\_PDR\_REG** (\*((volatile **uint32** \*)0x40024514))
- #define GPIO\_PORTE\_DEN\_REG (\*((volatile uint32 \*)0x4002451C))
- #define **GPIO\_PORTE\_LOCK\_REG** (\*((volatile **uint32** \*)0x40024520))
- #define **GPIO\_PORTE\_CR\_REG** (\*((volatile **uint32** \*)0x40024524))
- #define GPIO\_PORTE\_AMSEL\_REG (\*((volatile uint32 \*)0x40024528))
- #define GPIO\_PORTE\_PCTL\_REG (\*((volatile uint32 \*)0x4002452C))
- #define GPIO\_PORTE\_IS\_REG (\*((volatile uint32 \*)0x40024404))
- #define GPIO\_PORTE\_IBE\_REG (\*((volatile uint32 \*)0x40024408))
- #define **GPIO\_PORTE\_IEV\_REG** (\*((volatile **uint32** \*)0x4002440C))
- #define **GPIO\_PORTE\_IM\_REG** (\*((volatile **uint32** \*)0x40024410))
- #define GPIO\_PORTE\_RIS\_REG (\*((volatile uint32 \*)0x40024414))
   #define CPIO\_PORTE\_ICP\_REG (\*((volatile uint32 \*)0x40024416))
- #define **GPIO\_PORTE\_ICR\_REG** (\*((volatile **uint32** \*)0x4002441C))
- #define **GPIO\_PORTF\_DATA\_REG** (\*((volatile **uint32** \*)0x400253FC))
- #define GPIO\_PORTF\_DIR\_REG (\*((volatile uint32 \*)0x40025400))
   #define GPIO\_PORTF\_AFSEL\_REG (\*((volatile uint32 \*)0x40025420))
- #define GPIO\_PORTF\_PUR\_REG (\*((volatile uint32 \*)0x40025510))
- #define GPIO\_PORTF\_PDR\_REG (\*((volatile uint32 \*)0x40025514))

```
#define GPIO_PORTF_DEN_REG (*((volatile uint32 *)0x4002551C))
```

- #define **GPIO\_PORTF\_LOCK\_REG** (\*((volatile **uint32** \*)0x40025520))
- #define **GPIO\_PORTF\_CR\_REG** (\*((volatile **uint32** \*)0x40025524))
- #define GPIO\_PORTF\_AMSEL\_REG (\*((volatile uint32 \*)0x40025528))
- #define GPIO\_PORTF\_PCTL\_REG (\*((volatile uint32 \*)0x4002552C))
- #define **GPIO PORTF IS REG** (\*((volatile **uint32** \*)0x40025404))
- #define **GPIO\_PORTF\_IBE\_REG** (\*((volatile **uint32** \*)0x40025408))
- #define **GPIO\_PORTF\_IEV\_REG** (\*((volatile **uint32** \*)0x4002540C))
- #define **GPIO PORTF IM REG** (\*((volatile **uint32** \*)0x40025410))
- #define **GPIO\_PORTF\_RIS\_REG** (\*((volatile **uint32** \*)0x40025414))
- #define **GPIO\_PORTF\_ICR\_REG** (\*((volatile **uint32** \*)0x4002541C))
- #define **SYSCTL\_REGCGC2\_REG** (\*((volatile **uint32** \*)0x400FE108))
- #define **SYSTICK CTRL REG** (\*((volatile **uint32** \*)0xE000E010))
- #define SYSTICK RELOAD REG (\*((volatile uint32 \*)0xE000E014))
- #define **SYSTICK CURRENT REG** (\*((volatile **uint32** \*)0xE000E018))
- #define SYSCTL\_RIS\_REG (\*((volatile uint32 \*)0x400FE050))
- #define SYSCTL\_RCC\_REG (\*((volatile uint32 \*)0x400FE060))
- #define SYSCTL\_RCC2\_REG (\*((volatile uint32 \*)0x400FE070))
- #define NVIC\_PRI0\_REG (\*((volatile uint32 \*)0xE000E400))
- #define NVIC\_PRI1\_REG (\*((volatile uint32 \*)0xE000E404))
- #define NVIC\_PRI2\_REG (\*((volatile uint32 \*)0xE000E408))
- #define NVIC\_PRI3\_REG (\*((volatile uint32 \*)0xE000E40C))
- #define NVIC\_PRI4\_REG (\*((volatile uint32 \*)0xE000E410))
- #define NVIC\_PRI5\_REG (\*((volatile uint32 \*)0xE000E414))
- #define NVIC\_PRI6\_REG (\*((volatile uint32 \*)0xE000E418))
- #define **NVIC PRI7 REG** (\*((volatile **uint32** \*)0xE000E41C))
- #define NVIC\_PRI8\_REG (\*((volatile uint32 \*)0xE000E420))
- #define NVIC\_PRI9\_REG (\*((volatile uint32 \*)0xE000E424))
- #define NVIC\_PRI10\_REG (\*((volatile uint32 \*)0xE000E428))
- #define NVIC PRI11 REG (\*((volatile uint32 \*)0xE000E42C))
- #define **NVIC PRI12 REG** (\*((volatile **uint32** \*)0xE000E430))
- #define NVIC PRI13 REG (\*((volatile uint32 \*)0xE000E434))
- #define NVIC\_PRI14\_REG (\*((volatile uint32 \*)0xE000E438))
- #define NVIC\_PRI15\_REG (\*((volatile uint32 \*)0xE000E43C))
- #define NVIC\_PRI16\_REG (\*((volatile uint32 \*)0xE000E440)) #define NVIC\_PRI17\_REG (\*((volatile uint32 \*)0xE000E444))
- #define NVIC\_PRI18\_REG (\*((volatile uint32 \*)0xE000E448))
- #define NVIC\_PRI19\_REG (\*((volatile uint32 \*)0xE000E44C))
- #define NVIC\_PRI20\_REG (\*((volatile uint32 \*)0xE000E450))
- #define NVIC PRI21 REG (\*((volatile uint32 \*)0xE000E454))
- #define NVIC\_PRI22\_REG (\*((volatile uint32 \*)0xE000E458))
- #define NVIC\_PRI23\_REG (\*((volatile uint32 \*)0xE000E45C))
- #define NVIC PRI24 REG (\*((volatile uint32 \*)0xE000E460))
- #define NVIC\_PRI25\_REG (\*((volatile uint32 \*)0xE000E464))
- #define NVIC\_PRI26\_REG (\*((volatile uint32 \*)0xE000E468))
- #define NVIC\_PRI27\_REG (\*((volatile uint32 \*)0xE000E46C)) #define NVIC PRI28 REG (\*((volatile uint32 \*)0xE000E470))
- #define NVIC PRI29 REG (\*((volatile uint32 \*)0xE000E474))
- #define NVIC PRI30 REG (\*((volatile uint32 \*)0xE000E478))
- #define NVIC PRI31 REG (\*((volatile uint32 \*)0xE000E47C))
- #define NVIC\_PRI32\_REG (\*((volatile uint32 \*)0xE000E480))
- #define NVIC\_PRI33\_REG (\*((volatile uint32 \*)0xE000E484))
- #define NVIC\_PRI34\_REG (\*((volatile uint32 \*)0xE000E488))
- #define **NVIC\_EN0\_REG** (\*((volatile **uint32** \*)0xE000E100))
- #define **NVIC\_EN1\_REG** (\*((volatile **uint32** \*)0xE000E104))
- #define NVIC\_EN2\_REG (\*((volatile uint32 \*)0xE000E108))
- #define NVIC EN3 REG (\*((volatile uint32 \*)0xE000E10C))

- #define NVIC\_EN4\_REG (\*((volatile uint32 \*)0xE000E110))
- #define **NVIC\_DIS0\_REG** (\*((volatile **uint32** \*)0xE000E180))
- #define **NVIC\_DIS1\_REG** (\*((volatile **uint32** \*)0xE000E184))
- #define **NVIC\_DIS2\_REG** (\*((volatile **uint32** \*)0xE000E188))
- #define **NVIC\_DIS3\_REG** (\*((volatile **uint32** \*)0xE000E18C))
- #define **NVIC\_DIS4\_REG** (\*((volatile **uint32** \*)0xE000E190))
- #define NVIC\_SYSTEM\_PRI1\_REG (\*((volatile uint32 \*)0xE000ED18))
- #define NVIC\_SYSTEM\_PRI2\_REG (\*((volatile uint32 \*)0xE000ED1C))
- #define NVIC\_SYSTEM\_PRI3\_REG (\*((volatile uint32 \*)0xE000ED20))
- #define NVIC\_SYSTEM\_SYSHNDCTRL (\*((volatile uint32 \*)0xE000ED24))

### **Macro Definition Documentation**

```
#define GPIO PORTA AFSEL REG (*((volatile uint32 *)0x40004420))
#define GPIO_PORTA_AMSEL_REG (*((volatile uint32 *)0x40004528))
#define GPIO_PORTA_CR_REG (*((volatile uint32 *)0x40004524))
#define GPIO_PORTA_DATA_REG (*((volatile uint32 *)0x400043FC))
#define GPIO_PORTA_DEN_REG (*((volatile uint32 *)0x4000451C))
#define GPIO_PORTA_DIR_REG (*((volatile uint32 *)0x40004400))
#define GPIO_PORTA_IBE_REG (*((volatile uint32 *)0x40004408))
#define GPIO_PORTA_ICR_REG (*((volatile uint32 *)0x4000441C))
#define GPIO_PORTA_IEV_REG (*((volatile uint32 *)0x4000440C))
#define GPIO PORTA IM REG (*((volatile uint32 *)0x40004410))
#define GPIO_PORTA_IS_REG (*((volatile uint32 *)0x40004404))
#define GPIO_PORTA_LOCK_REG (*((volatile uint32 *)0x40004520))
#define GPIO_PORTA_PCTL_REG (*((volatile uint32 *)0x4000452C))
#define GPIO_PORTA_PDR_REG (*((volatile uint32 *)0x40004514))
#define GPIO_PORTA_PUR_REG (*((volatile uint32 *)0x40004510))
#define GPIO_PORTA_RIS_REG (*((volatile uint32 *)0x40004414))
#define GPIO_PORTB_AFSEL_REG (*((volatile uint32 *)0x40005420))
#define GPIO_PORTB_AMSEL_REG (*((volatile uint32 *)0x40005528))
#define GPIO_PORTB_CR_REG (*((volatile uint32 *)0x40005524))
#define GPIO_PORTB_DATA_REG (*((volatile uint32 *)0x400053FC))
#define GPIO_PORTB_DEN_REG (*((volatile uint32 *)0x4000551C))
#define GPIO_PORTB_DIR_REG (*((volatile uint32 *)0x40005400))
#define GPIO_PORTB_IBE_REG (*((volatile uint32 *)0x40005408))
#define GPIO_PORTB_ICR_REG (*((volatile uint32 *)0x4000541C))
#define GPIO_PORTB_IEV_REG (*((volatile uint32 *)0x4000540C))
```

#define GPIO\_PORTB\_IM\_REG (\*((volatile uint32 \*)0x40005410)) #define GPIO PORTB IS REG (\*((volatile uint32 \*)0x40005404)) #define GPIO\_PORTB\_LOCK\_REG (\*((volatile uint32 \*)0x40005520)) #define GPIO\_PORTB\_PCTL\_REG (\*((volatile uint32 \*)0x4000552C)) #define GPIO\_PORTB\_PDR\_REG (\*((volatile uint32 \*)0x40005514)) #define GPIO\_PORTB\_PUR\_REG (\*((volatile uint32 \*)0x40005510)) #define GPIO\_PORTB\_RIS\_REG (\*((volatile uint32 \*)0x40005414)) #define GPIO\_PORTC\_AFSEL\_REG (\*((volatile uint32 \*)0x40006420)) #define GPIO\_PORTC\_AMSEL\_REG (\*((volatile uint32 \*)0x40006528)) #define GPIO\_PORTC\_CR\_REG (\*((volatile uint32 \*)0x40006524)) #define GPIO\_PORTC\_DATA\_REG (\*((volatile uint32 \*)0x400063FC)) #define GPIO\_PORTC\_DEN\_REG (\*((volatile uint32 \*)0x4000651C)) #define GPIO\_PORTC\_DIR\_REG (\*((volatile uint32 \*)0x40006400)) #define GPIO\_PORTC\_IBE\_REG (\*((volatile uint32 \*)0x40006408)) #define GPIO\_PORTC\_ICR\_REG (\*((volatile uint32 \*)0x4000641C)) #define GPIO\_PORTC\_IEV\_REG (\*((volatile uint32 \*)0x4000640C)) #define GPIO\_PORTC\_IM\_REG (\*((volatile uint32 \*)0x40006410)) #define GPIO\_PORTC\_IS\_REG (\*((volatile uint32 \*)0x40006404)) #define GPIO PORTC LOCK REG (\*((volatile uint32 \*)0x40006520)) #define GPIO\_PORTC\_PCTL\_REG (\*((volatile uint32 \*)0x4000652C)) #define GPIO\_PORTC\_PDR\_REG (\*((volatile uint32 \*)0x40006514)) #define GPIO\_PORTC\_PUR\_REG (\*((volatile uint32 \*)0x40006510)) #define GPIO\_PORTC\_RIS\_REG (\*((volatile uint32 \*)0x40006414)) #define GPIO\_PORTD\_AFSEL\_REG (\*((volatile uint32 \*)0x40007420)) #define GPIO\_PORTD\_AMSEL\_REG (\*((volatile uint32 \*)0x40007528)) #define GPIO\_PORTD\_CR\_REG (\*((volatile uint32 \*)0x40007524))

```
#define GPIO_PORTD_DATA_REG (*((volatile uint32 *)0x400073FC))
#define GPIO PORTD DEN REG (*((volatile uint32 *)0x4000751C))
#define GPIO_PORTD_DIR_REG (*((volatile uint32 *)0x40007400))
#define GPIO_PORTD_IBE_REG (*((volatile uint32 *)0x40007408))
#define GPIO_PORTD_ICR_REG (*((volatile uint32 *)0x4000741C))
#define GPIO_PORTD_IEV_REG (*((volatile uint32 *)0x4000740C))
#define GPIO_PORTD_IM_REG (*((volatile uint32 *)0x40007410))
#define GPIO_PORTD_IS_REG (*((volatile uint32 *)0x40007404))
#define GPIO_PORTD_LOCK_REG (*((volatile uint32 *)0x40007520))
#define GPIO_PORTD_PCTL_REG (*((volatile uint32 *)0x4000752C))
#define GPIO_PORTD_PDR_REG (*((volatile uint32 *)0x40007514))
#define GPIO_PORTD_PUR_REG (*((volatile uint32 *)0x40007510))
#define GPIO_PORTD_RIS_REG (*((volatile uint32 *)0x40007414))
#define GPIO_PORTE_AFSEL_REG (*((volatile uint32 *)0x40024420))
#define GPIO_PORTE_AMSEL_REG (*((volatile uint32 *)0x40024528))
#define GPIO_PORTE_CR_REG (*((volatile uint32 *)0x40024524))
#define GPIO_PORTE_DATA_REG (*((volatile uint32 *)0x400243FC))
#define GPIO_PORTE_DEN_REG (*((volatile uint32 *)0x4002451C))
#define GPIO PORTE DIR REG (*((volatile uint32 *)0x40024400))
#define GPIO_PORTE_IBE_REG (*((volatile uint32 *)0x40024408))
#define GPIO_PORTE_ICR_REG (*((volatile uint32 *)0x4002441C))
#define GPIO_PORTE_IEV_REG (*((volatile uint32 *)0x4002440C))
#define GPIO_PORTE_IM_REG (*((volatile uint32 *)0x40024410))
#define GPIO_PORTE_IS_REG (*((volatile uint32 *)0x40024404))
#define GPIO_PORTE_LOCK_REG (*((volatile uint32 *)0x40024520))
#define GPIO PORTE PCTL REG (*((volatile uint32 *)0x4002452C))
```

```
#define GPIO_PORTE_PDR_REG (*((volatile uint32 *)0x40024514))
#define GPIO_PORTE_PUR_REG (*((volatile uint32 *)0x40024510))
#define GPIO_PORTE_RIS_REG (*((volatile uint32 *)0x40024414))
#define GPIO_PORTF_AFSEL_REG (*((volatile uint32 *)0x40025420))
#define GPIO_PORTF_AMSEL_REG (*((volatile uint32 *)0x40025528))
#define GPIO_PORTF_CR_REG (*((volatile uint32 *)0x40025524))
#define GPIO_PORTF_DATA_REG (*((volatile uint32 *)0x400253FC))
#define GPIO_PORTF_DEN_REG (*((volatile uint32 *)0x4002551C))
#define GPIO_PORTF_DIR_REG (*((volatile uint32 *)0x40025400))
#define GPIO_PORTF_IBE_REG (*((volatile uint32 *)0x40025408))
#define GPIO_PORTF_ICR_REG (*((volatile uint32 *)0x4002541C))
#define GPIO_PORTF_IEV_REG (*((volatile uint32 *)0x4002540C))
#define GPIO_PORTF_IM_REG (*((volatile uint32 *)0x40025410))
#define GPIO_PORTF_IS_REG (*((volatile uint32 *)0x40025404))
#define GPIO_PORTF_LOCK_REG (*((volatile uint32 *)0x40025520))
#define GPIO_PORTF_PCTL_REG (*((volatile uint32 *)0x4002552C))
#define GPIO_PORTF_PDR_REG (*((volatile uint32 *)0x40025514))
#define GPIO_PORTF_PUR_REG (*((volatile uint32 *)0x40025510))
#define GPIO PORTF RIS REG (*((volatile uint32 *)0x40025414))
#define NVIC_DIS0_REG (*((volatile uint32 *)0xE000E180))
#define NVIC_DIS1_REG (*((volatile uint32 *)0xE000E184))
#define NVIC_DIS2_REG (*((volatile uint32 *)0xE000E188))
#define NVIC_DIS3_REG (*((volatile uint32 *)0xE000E18C))
#define NVIC_DIS4_REG (*((volatile uint32 *)0xE000E190))
#define NVIC_EN0_REG (*((volatile uint32 *)0xE000E100))
#define NVIC EN1 REG (*((volatile uint32 *)0xE000E104))
```

```
#define NVIC_EN2_REG (*((volatile uint32 *)0xE000E108))
#define NVIC_EN3_REG (*((volatile uint32 *)0xE000E10C))
#define NVIC_EN4_REG (*((volatile uint32 *)0xE000E110))
#define NVIC_PRI0_REG (*((volatile uint32 *)0xE000E400))
#define NVIC_PRI10_REG (*((volatile uint32 *)0xE000E428))
#define NVIC_PRI11_REG (*((volatile uint32 *)0xE000E42C))
#define NVIC_PRI12_REG (*((volatile uint32 *)0xE000E430))
#define NVIC_PRI13_REG (*((volatile uint32 *)0xE000E434))
#define NVIC_PRI14_REG (*((volatile uint32 *)0xE000E438))
#define NVIC_PRI15_REG (*((volatile uint32 *)0xE000E43C))
#define NVIC_PRI16_REG (*((volatile uint32 *)0xE000E440))
#define NVIC_PRI17_REG (*((volatile uint32 *)0xE000E444))
#define NVIC_PRI18_REG (*((volatile uint32 *)0xE000E448))
#define NVIC_PRI19_REG (*((volatile uint32 *)0xE000E44C))
#define NVIC_PRI1_REG (*((volatile uint32 *)0xE000E404))
#define NVIC_PRI20_REG (*((volatile uint32 *)0xE000E450))
#define NVIC_PRI21_REG (*((volatile uint32 *)0xE000E454))
#define NVIC_PRI22_REG (*((volatile uint32 *)0xE000E458))
#define NVIC PRI23 REG (*((volatile uint32 *)0xE000E45C))
#define NVIC_PRI24_REG (*((volatile uint32 *)0xE000E460))
#define NVIC_PRI25_REG (*((volatile uint32 *)0xE000E464))
#define NVIC_PRI26_REG (*((volatile uint32 *)0xE000E468))
#define NVIC_PRI27_REG (*((volatile uint32 *)0xE000E46C))
#define NVIC_PRI28_REG (*((volatile uint32 *)0xE000E470))
#define NVIC_PRI29_REG (*((volatile uint32 *)0xE000E474))
#define NVIC_PRI2_REG (*((volatile uint32 *)0xE000E408))
```

```
#define NVIC_PRI30_REG (*((volatile uint32 *)0xE000E478))
#define NVIC_PRI31_REG (*((volatile uint32 *)0xE000E47C))
#define NVIC_PRI32_REG (*((volatile uint32 *)0xE000E480))
#define NVIC_PRI33_REG (*((volatile uint32 *)0xE000E484))
#define NVIC_PRI34_REG (*((volatile uint32 *)0xE000E488))
#define NVIC_PRI3_REG (*((volatile uint32 *)0xE000E40C))
#define NVIC_PRI4_REG (*((volatile uint32 *)0xE000E410))
#define NVIC_PRI5_REG (*((volatile uint32 *)0xE000E414))
#define NVIC_PRI6_REG (*((volatile uint32 *)0xE000E418))
#define NVIC_PRI7_REG (*((volatile uint32 *)0xE000E41C))
#define NVIC_PRI8_REG (*((volatile uint32 *)0xE000E420))
#define NVIC_PRI9_REG (*((volatile uint32 *)0xE000E424))
#define NVIC_SYSTEM_PRI1_REG (*((volatile uint32 *)0xE000ED18))
#define NVIC_SYSTEM_PRI2_REG (*((volatile uint32 *)0xE000ED1C))
#define NVIC_SYSTEM_PRI3_REG (*((volatile uint32 *)0xE000ED20))
#define NVIC_SYSTEM_SYSHNDCTRL (*((volatile uint32 *)0xE000ED24))
#define SYSCTL_RCC2_REG (*((volatile uint32 *)0x400FE070))
#define SYSCTL_RCC_REG (*((volatile uint32 *)0x400FE060))
#define SYSCTL_REGCGC2_REG (*((volatile uint32 *)0x400FE108))
#define SYSCTL_RIS_REG (*((volatile uint32 *)0x400FE050))
#define SYSTICK_CTRL_REG (*((volatile uint32 *)0xE000E010))
#define SYSTICK_CURRENT_REG (*((volatile uint32 *)0xE000E018))
#define SYSTICK_RELOAD_REG (*((volatile uint32 *)0xE000E014))
```

## tm4c123gh6pm\_startup\_ccs.c File Reference

#include <stdint.h>

Include dependency graph for tm4c123gh6pm\_startup\_ccs.c:



### **Functions**

- void **ResetISR** (void)
- void \_c\_int00 (void)

### **Variables**

- uint32\_t \_\_STACK\_TOP
- void(\*const **g\_pfnVectors** [])(void)

### **Function Documentation**

void \_c\_int00 (void )

void ResetISR (void)

#### **Variable Documentation**

uint32\_t \_\_STACK\_TOP

void(\* const g\_pfnVectors[])(void)

# Index

INDEX